https://www.acmicpc.net/problem/1501
문제
혹시 인터넷을 하다가, 다음과 같은 식의 문장을 본 적이 있는가?
It is itnersetnig taht pepole can raed smoe grabeld wrods.
원래의 문장은 'It is interesting that people can read some garbled words'이다. 각각의 단어들은 제일 첫 문자와 제일 끝 문자를 제외하고는 순서가 뒤섞여 있다. 한 대학에서 시행한 연구 조사 결과에 따르면, (영어 단어를 아는 사람의 경우) 첫 문자와 제일 끝 문자가 일치하고, 그 사이의 문자들은 순서가 어떻게 뒤바뀌어 있더라도 읽는 데 지장이 없다고 한다.
그렇다보니, 한 단어가 여러 단어로 해석될 수도 있다. 예를 들어 abcde와 같은 단어는, abcde, abdce, acbde, acdbe, adbce, adcbe 같은 단어들로 해석될 수도 있다. 물론 각각의 단어들이 실제로 존재하는 단어(사전에 존재하는 단어)일 경우에만 의미가 있다.
영어 문장이 주어졌을 때, 그 문장을 해석하는 방법의 경우의 수를 구하는 프로그램을 작성하시오. 각각의 단어는, 첫 글자와 끝 글자가 일치하는 다른 단어(사전에 존재하는)로 해석할 수 있다. 영어 문장은 하나 이상의 단어로 이루어져 있으며, 각 단어들은 공백으로 구분되어 있다.
입력
첫째 줄에 사전에 있는 단어들의 개수 N(0 ≤ N ≤ 10,000)이 주어진다. 다음 N개의 줄에는 각 줄에 하나씩, 영어 사전에 있는 단어들이 주어진다. 각 단어의 길이는 100자를 넘지 않는다. 다음 줄에 해석할 문장의 개수 M(0 ≤ M ≤ 10,000)이 주어진다. 다음 M개의 줄에는 각 줄에 하나씩 문장이 주어진다. 각 문장의 길이는 10,000자를 넘지 않는다. 영어 단어는 알파벳 대소문자(구별됨)로만 이루어진다.
출력
M개의 줄에, 각 문장을 해석하는 경우의 수를 출력한다. 답은 32-bit signed int 범위 안에 있다고 가정하자.
풀이
Code
import sys
from collections import defaultdict
input = sys.stdin.readline
def solution():
# 1. 딕셔너리 생성
case = defaultdict(int)
# 2.
for _ in range(int(input())) :
# 2-1. 입력된 문자의 양 끝을 제외한 나머지 정렬
string = list(input().rstrip())
if len(string) > 2 : string = [string[0]] + sorted(string[1:-1]) + [string[-1]]
# 2-2. 매핑된 값 추가
case[tuple(string)] += 1
# 3.
for _ in range(int(input())) :
# 3-1. 문장 입력받기
sentence = list(map(str, input().rstrip().split()))
# 3-2. 각 단어 정렬
for idx, word in enumerate(sentence) :
if len(word) > 2: sentence[idx] = [word[0]] + sorted(word[1:-1]) + [word[-1]]
# 3-3.
answer = 0
for idx, c in enumerate(sentence) :
if idx == 0 :
answer = case[tuple(c)]
else :
answer *= case[tuple(c)]
# 3-4. 결과 출력
print(answer)
if __name__ == "__main__" :
solution()
'Coding Test > Baekjoon' 카테고리의 다른 글
[Python/BOJ] 2533. 사회망 서비스(SNS) (0) | 2023.12.04 |
---|---|
[Python/BOJ] 15683. 감시 (0) | 2023.12.01 |
[Python/BOJ] 1430. 공격 (2) | 2023.11.29 |
[Python/BOJ] 17503. 맥주 축제 (1) | 2023.11.28 |
[Python/BOJ] 1105. 팔 (0) | 2023.11.27 |