반응형
문제
https://www.acmicpc.net/problem/1235
이번에는 학생들을 더욱 효율적으로 관리하기 위해 학생마다 고유한 학생 번호를 부여하기로 하였다. 학생 번호는 0부터 9 사이의 숫자로 이루어진 문자열로, 모든 학생들의 학생 번호는 서로 다르지만 그 길이는 모두 같다.
학생들의 번호를 부여해 놓고 보니, 김진영 조교는 어쩌면 번호가 지나치게 긴 것은 아닌가 싶은 생각이 들었다. 예를 들어 아래와 같은 7자리의 학생 번호를 보자.
이름번호
오민식 | 1212345 |
김형택 | 1212356 |
이동호 | 0033445 |
이처럼 학생 번호를 굳이 7자리로 하지 않고, 뒤에서 세 자리만을 추려서 남겨 놓아도 모든 학생들의 학생 번호를 서로 다르게 만들 수 있다.
이름번호오민식 | 345 |
김형택 | 356 |
이동호 | 445 |
하지만 세 자리보다 적게 남겨 놓아서는 모든 학생들의 학생 번호를 서로 다르게 만들 수 없다.
학생들의 번호가 주어 졌을 때, 뒤에서 k자리만을 추려서 남겨 놓았을 때 모든 학생들의 학생 번호를 서로 다르게 만들 수 있는 최소의 k를 구하는 프로그램을 작성하시오.
입력
첫째 줄에는 학생의 수 N(2≤N≤1,000)이 주어진다. 둘째 줄부터 N개의 줄에 걸쳐 각 학생의 학생 번호가 순서대로 주어진다. 모든 학생들의 학생 번호는 서로 다르지만 그 길이는 모두 같으며, 0부터 9 사이의 숫자로 이루어진 문자열이 주어진다. 문자열의 길이는 100보다 작거나 같다.
출력
첫째 줄에 구하고자 하는 가장 작은 k값을 출력한다.
코드
import sys
input=sys.stdin.readline
n=int(input())
data=[list(map(int, input().strip())) for _ in range(n)]
length=len(data[0])
for i in range(length-1, -1, -1):
tmp=[[] for _ in range(n)]
setA=set()
for j in range(n):
tmp[j].append(data[j][i:length])
setA.add(str(tmp[j]))
if len(setA)==n:
print(length-i)
break
문제 해결
문자열과 집합의 자료구조를 사용한 기본적인 파이썬 문제이다.
집합을 활용하면 중복을 제거한 자료구조를 쉽게 사용할수 있다.
반응형
'Problem Solving > 백준' 카테고리의 다른 글
[백준] 1260번: DFS와 BFS - [Python/파이썬] (0) | 2023.04.12 |
---|---|
[백준] 1245번: 농장관리 - [Python/파이썬] (0) | 2023.04.12 |
[백준] 1212번: 8진수 2진수 - [Python/파이썬] (0) | 2023.04.12 |
[백준] 1205번: 등수구하기 - [Python/파이썬] (0) | 2023.04.12 |
[백준] 1182번: 부분수열의 합 - [Python/파이썬] (0) | 2023.04.11 |