| ps | |
|---|---|
| 링크 | programmers.co.kr/… |
| 출처 | 프로그래머스 |
| 문제 번호 | 60057 |
| 문제명 | 문자열 압축 |
| 레벨 | Level 2 |
| 분류 |
기초 |
| 시간복잡도 | O(nlogn) |
| 인풋사이즈 | n<=1000 |
| 사용한 언어 | Python |
| 해결날짜 | 2021/07/30 |
"""Solution code for "Programmers 60057. 문자열 압축".
- Problem link: https://programmers.co.kr/learn/courses/30/lessons/60057
- Solution link: http://www.teferi.net/ps/problems/programmers/60057
"""
import itertools
def chars(group, size):
count = sum(1 for _ in group)
if count > 1:
return size + len(str(count))
else:
return size
def solution(s):
answer = len(s)
for size in range(1, len(s)):
pieces = (s[pos:pos + size] for pos in range(0, len(s), size))
length = sum(chars(g, len(k)) for k, g in itertools.groupby(pieces))
answer = min(answer, length)
return answer