1 분 소요

1. 문제

https://www.acmicpc.net/problem/2607

  • 문자열 문제
// 문제
영문 알파벳 대문자로 이루어진  단어가 
다음의  가지 조건을 만족하면 같은 구성을 갖는다고 말한다.

 개의 단어가 같은 종류의 문자로 이루어져 있다.
같은 문자는 같은 개수 만큼 있다.
예를 들어 "DOG" "GOD"   'D', 'G', 'O' 
 종류의 문자로 이루어져 있으며 
양쪽 모두 'D', 'G', 'O'  하나씩 있으므로 
 둘은 같은 구성을 갖는다. 
하지만 "GOD" "GOOD" 경우 "GOD"에는 'O' 하나, 
"GOOD"에는 'O'   있으므로 
 둘은 다른 구성을 갖는다.

 단어가 같은 구성을 갖는 경우, 
또는  단어에서  문자를 더하거나, 빼거나, 
하나의 문자를 다른 문자로 바꾸어 
나머지  단어와 같은 구성을 갖게 되는 경우에 
이들  단어를 서로 비슷한 단어라고 한다.

예를 들어 "DOG" "GOD" 같은 구성을 가지므로 
 둘은 비슷한 단어이다. 
또한 "GOD"에서 'O' 하나 추가하면 "GOOD"  같은 구성을 갖게 되므로 
  또한 비슷한 단어이다. 
하지만 "DOG"에서 하나의 문자를 더하거나, 빼거나, 바꾸어도 
"DOLL" 같은 구성이 되지는 않으므로 
"DOG" "DOLL" 비슷한 단어가 아니다.

입력으로 여러 개의 서로 다른 단어가 주어질 , 
 번째 단어와 비슷한 단어가 모두  개인지 찾아 출력하는 프로그램을 작성하시오.

// 입력
첫째 줄에는 단어의 개수가 주어지고 
둘째 줄부터는  줄에 하나씩 단어가 주어진다. 
모든 단어는 영문 알파벳 대문자로 이루어져 있다. 
단어의 개수는 100 이하이며,  단어의 길이는 10 이하이다.

// 출력
입력으로 주어진  번째 단어와 비슷한 단어가  개인지 첫째 줄에 출력한다.

// 예제 입력 1 
4
DOG
GOD
GOOD
DOLL

// 예제 출력 1 
2


2. 핵심 아이디어


3. Python 문제풀이

import sys
import copy
input = sys.stdin.readline

n = int(input())
words = [input().rstrip() for _ in range(n)]
word = {}

for w in words[0] :
  if w in word :
    word[w] += 1
  else :
    word[w] = 1

result = 0

for i in range(1, n) :
  if len(words[i]) > len(words[0]) + 1 or len(words[i]) < len(words[0]) - 1 :
    continue
    
  ck = copy.deepcopy(word)
  
  for w in words[i] :
    if w in ck :
      ck[w] -= 1
    else :
      ck[w] = -1
      
  change = [0, 0]
  flag = True
  
  for c in ck :
    if ck[c] == 0 :
      continue
    if ck[c] == 1 :
      change[1] += 1
    elif ck[c] == -1 :
      change[0] += 1
    else :
      flag = False
      break

  if sum(change) > 2 :
    flag = False
  elif change[0] > 2 or change[1] > 2 :
    flag = False

  if flag :
    result += 1

print(result)


4. Java 문제풀이


댓글남기기