https://www.acmicpc.net/problem/11478
set의 경우 해시맵으로 구현이 되어 있으며, 해시 충돌이 일어날 경우 선형 탐색을 하기 때문에 worst case의 시간복잡도가 O(N)입니다.
위쪽 코드는 모든 길이의 substring을 하나의 해시맵에 넣어 해시 충돌이 일어날 가능성이 높고, 아래 코드는 길이별로 substring을 따로 세기 때문에 해시 충돌이 일어날 가능성이 더 낮습니다.
# (속도:약 500ms)
s = input()
subset = set()
for i in range(1, len(s)+1):
for j in range(len(s)-i+1):
subset.add(s[j:j+i])
print(len(subset))
# (속도: 약 200ms)
def substring(s, l):
subs = set()
for i in range(len(s)-(l-1)):
subs.add(s[i:i+l])
return subs
word = input()
substrs=0
for i in range(len(word)):
substrs+=len(substring(word, i+1))
print(substrs)
이렇게 맞으면 찝찝해
'개발 언어 > Python' 카테고리의 다른 글
[나도코딩의 파이썬 입문] 코딩 자율학습단 2기 Chap1 ~ Chap4 (0) | 2023.03.10 |
---|