반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 웹프로그래밍
- C++
- 배열
- web
- dp
- 코테연습
- 리트코드
- react
- CS
- Level3
- 리액트
- VUE
- Doitvue.js입문
- OS
- sql
- 카카오
- javascript
- 자바스크립트
- Medium
- 동적계획법
- 고득점Kit
- Level2
- 프로그래밍
- 백준
- LeetCode
- 파이썬
- typescript
- 프로그래머스
- Level1
- python
Archives
- Today
- Total
[프로그래머스] 압축 - python 본문
반응형
압축
문제
LZW 압축은 다음 과정을 거친다.
- 길이가 1인 모든 단어를 포함하도록 사전을 초기화한다.
- 사전에서 현재 입력과 일치하는 가장 긴 문자열 w를 찾는다.
- w에 해당하는 사전의 색인 번호를 출력하고, 입력에서 w를 제거한다.
- 입력에서 처리되지 않은 다음 글자가 남아있다면(c), w+c에 해당하는 단어를 사전에 등록한다.
- 단계 2로 돌아간다.
주어진 문자열을 압축한 후의 사전 색인 번호를 배열로 출력하라.
제한사항
- 입력으로 영문 대문자로만 이뤄진 문자열 msg가 주어진다. msg의 길이는 1 글자 이상, 1000 글자 이하이다.
풀이
처음에는 재귀로 구현했다가 너무 느려서 반복문으로 바꿨다.
- 사전에 존재하는 가장 긴 배열을 찾는다. (w)
- 나머지 글자 한 개를 더한 값을 사전에 등록한다. (w + c )
- 해당 문자의 색인번호를 answer에 넣는다.
- msg에서 w를 제거한다.
def solution(msg):
answer = []
dictionary = {chr(i + 65): i + 1 for i in range(0, 27)}
i = 0
while msg:
j = i + 1
while msg[i : j] in dictionary.keys() and j <= len(msg):
j += 1
if msg[i : j] not in dictionary.keys():
dictionary[msg[i : j]] = len(dictionary)
answer.append(dictionary[msg[i : j - 1]])
msg = msg[j - 1:]
return answer
반응형
'코테 문제 풀이' 카테고리의 다른 글
[프로그래머스] N진수 게임 - python (0) | 2022.04.21 |
---|---|
[프로그래머스] 파일명 정렬 - python (0) | 2022.04.21 |
[프로그래머스] 방금그곡 - python (0) | 2022.04.20 |
[프로그래머스] 캐시 - python (0) | 2022.04.20 |
[프로그래머스] 프렌즈4블록 - python (0) | 2022.04.20 |
Comments