내용으로 건너뛰기
테페리넷
사용자 도구
등록
로그인
사이트 도구
검색
도구
문서 보기
Fold/unfold all
역링크
미디어 관리자
사이트맵
등록
로그인
>
미디어 관리자
사이트맵
현재 위치:
테페리넷
»
Problem Solving
»
문제
»
프로그래머스
»
문자열 압축
ps:problems:programmers:60057
이 문서는 읽기 전용입니다. 원본을 볼 수는 있지만 바꿀 수는 없습니다. 문제가 있다고 생각하면 관리자에게 문의하세요.
====== 문자열 압축 ====== ===== 풀이 ===== * 그냥 무식하게, 문자를 1개단위, 2개단위, ..., |s|개 단위로 모두 압축해보고, 그중에서 가장 길이가 짧은것을 찾으면 된다. * 단위가 전체 길이의 절반을 넘어가면 압축이 불가능하므로, |s|/2 까지만 해봐도 되긴 하다만, 큰 의미는 없다. * i개 단위로 압축을 해볼때 걸리는 시간은, i값에 관계 없이 O(log|s|) 이다. 따라서 전체 시간 복잡도는 O(|s|*log|s|). * 실수하기 쉬운 부분은, i개 단위로 압축할 때 i길이의 문자열이 x번 반복된다면 압축된 길이는 i+1 이 아니라, i + len(str(x))이다. x가 1자리수보다 클 경우도 생각해야 한다는 의미이다. ===== 코드 ===== <dkpr py> """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 </dkpr> {{tag>프로그래머스 ps:problems:programmers:Level_2}}
ps/problems/programmers/60057.txt
· 마지막으로 수정됨: 2021/07/31 16:51 저자
teferi
문서 도구
문서 보기
역링크
Fold/unfold all
맨 위로