[Silver II] 앵무새 - 14713
성능 요약
메모리: 72104 KB, 시간: 64 ms
분류
자료 구조, 구현, 큐, 문자열
제출 일자
2024년 1월 1일 11:10:47
문제 설명
자가용 비행기를 타고 세계 일주를 하던 pps789와 cseteram은 어느 날 엔진 고장으로 인해 이름 모를 섬에 불시착하게 된다. 그들은 이 섬을 탐험하는 도중 아주 신기한 사실을 알게 되었는데, 바로 이 섬에 사는 앵무새들은 놀라울 정도로 인간의 말을 흉내 내는 데 뛰어나다는 것이다. 그들은 서로 떨어져 섬을 탐험하기로 하였으며, 필요하다면 앵무새를 이용해 서로에게 연락하기로 약속하였다.
1개월 후, pps789는 섬의 비밀을 밝힐 결정적인 증거를 찾게 된다. 그는 이 세기의 대발견을 cseteram에게 공유하고자 하였으나, 그의 발견은 방대하여 앵무새 한 마리가 기억하기에는 너무 많은 양이었다. 그렇기 에 pps789는 앵무새 한 마리 대신 앵무새 N마리를 이용하여 자신의 발견을 기록하였으며, 이 앵무새들을 cseteram을 향해 날렸다.
한편 섬의 반대편에서 탐험을 계속하던 cseteram은 앵무새 N마리가 자신에게 날아와 각자 할 말을 하는 것을 보고 당황하였다. pps789가 긴 글을 전달하고 싶었던 것은 알아차렸지만, 각각의 앵무새들이 말하는 것을 차례대로 기록하다 보니 원문이 무엇인지 알 수 없을 정도로 단어의 순서가 엉켜버린 것이다. 대신 그는 관찰을 통해 몇 가지 규칙을 발견할 수 있었다.
- 한 앵무새는 한 문장을 기억하고 있다. 문장은 여러 단어로 이루어져 있는데, 앵무새는 이 단어들을 순서대로 말한다.
- 한 앵무새가 단어를 말하고 그다음 단어를 말하기 전에는 약간의 간격이 있는데, 이때 다른 앵무새가 말을 가로채고 자신의 문장을 말할 수 있다.
- 한 앵무새가 단어를 말하는 도중에는, 다른 앵무새가 말을 가로채지 않는다.
- 어떤 단어도 앵무새가 말하는 모든 문장을 통틀어 2번 이상 등장하지 않는다.
앵무새는 자신이 기억하고 있는 문장을 끝까지 말한 다음 pps789에게 돌아가며, cseteram은 모든 앵무새가 돌아갈 때 까지 단어를 받아적는다. pps789가 각각의 앵무새들에게 전달한 문장 Si와, cseteram이 받아 적은 문장 L이 주어진다. 이때 문장 L이 위 규칙들을 이용하여 나올 수 있는 문장인지 판별하시오.
입력
첫 번째 줄에 앵무새의 수 N (1 ≤ N ≤ 100) 이 주어진다.
두 번째 줄부터 N개의 줄에 걸쳐 각 앵무새가 말한 문장 Si (1 ≤ i ≤ N) 가 주어지는데, 각 문장을 이루는 단어는 스페이스 한 칸을 구분으로 하여 주어진다. 문장 Si를 이루는 단어의 수는 1개 이상 100개 이하이며, 각 단어는 1개 이상 32개 이하의 영문 소문자로 구성되어있다.
N + 2 번째 줄에는 cseteram이 받아 적은 문장 L이 주어진다. 문장 L을 이루는 단어의 수는 1개 이상 10000개 이하이며, 각 단어는 1개 이상 32개 이하의 영문 소문자로 구성된다.
출력
문장 L이 가능한 문장이라면 Possible
을, 불가능한 문장이라면 Impossible
을 출력한다.
풀이
해당 문제를 보고 Queue의 성질인 FIFO를 이용하면 될 것이라고 생각하였습니다.
문장마다 배열을 생성해두고, 앵무새가 말하는 문장의 단어를 순회하면서 배열의 첫 번째 단어가 문장의 단어와 일치하면 넘어가고,
일치하는 것이 없다면 Impossible이 되는 것입니다.
하지만 여기서 문장을 다 말했음에도 배열에 단어가 남아있으면 정답이 아니기 때문에 이에 대한 확인도 해주었습니다.
그림으로 보면 다음과 같습니다. (대충 만들었어서,, 이해를 위한 것으로 생각해주시면 감사하겠습니다,,)
다음은 코드입니다.
let n = Int(readLine()!)!
var queues = [[String]]()
var (dequeue, ans) = ([String](), "Possible")
for _ in 0..<n {
let input = readLine()!.split(separator: " ").map { String($0) }
queues.append(input)
}
var sentence = readLine()!.split(separator: " ").map { String($0) }
for s in sentence {
var found = false
for (index, queue) in queues.enumerated() {
// 값이 있을 때
if !queue.isEmpty && queue.first! == s {
// 큐 연산
dequeue = queue.reversed()
dequeue.removeLast()
queues[index] = Array(dequeue.reversed())
found = true
break
}
}
if !found {
ans = "Impossible"
break
}
}
for queue in queues {
if !queue.isEmpty { // 큐에 단어가 남아있다면 Impossible
ans = "Impossible"
break
}
}
print(ans)
'PS > BOJ' 카테고리의 다른 글
[백준(BOJ)] 5397 키로거 - 스위프트 (Swift) (0) | 2024.01.03 |
---|---|
[백준(BOJ) 1966 프린터 큐 - 스위프트 (Swift) (0) | 2024.01.02 |
[백준(BOJ)] 10845 큐 - 스위프트 (Swift) (0) | 2024.01.02 |
[백준(BOJ)] 2304 창고 다각형 - 스위프트 (Swift) (0) | 2023.12.29 |
[백준(BOJ)] 2257 화학식량 - 스위프트 (Swift) (0) | 2023.12.28 |