일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- LF
- 프로그래머스
- password 안보임
- 응답코드
- 개행문자
- 참조타입
- input type password
- git autocrlf
- expected linebreaks to be 'crlf' but found 'lf' linebreak-style
- CRA
- eslint
- JadenCase
- expected linebreaks to be 'lf' but found 'crlf' linebreak-style
- HTTPS
- 가장큰수
- 퀵정렬
- 원시값
- git 명령어
- git
- IP주소
- k번째수
- git 개행문자
- input 안보임
- lazy-load
- prettier
- CRLF
- REST API
- eslint-prettier
- react
- vscode
Archives
- Today
- Total
우파루파의 개발 기록
[프로그래머스] 60057: 2020 KAKAO BLIND RECRUITMENT > 문자열 압축 본문
안녕하세요.
이번 문제는 프로그래머스의 60057번 입니다.
문자열을 압축하는 문제입니다.
문제
코드
def solution(s):
result = set([len(s)])
for i in range(1,len(s)):
result.add(len(string_zip(s, i)))
return min(result)
def string_zip(strs, n):
result = ""
target = strs[:n]
count = 1
for i in range(n, len(strs), n):
if strs[i:i+n] == target:
count += 1
else:
result += f"{count if count > 1 else ''}{target}"
count = 1
target = strs[i:i+n]
result += f"{count if count > 1 else ''}{target}"
return result
알고리즘 캔버스
아이디어
- 기본적으로 압축하지 않은 결과를 set 형식인 result에 저장한다.
- 만약 len이 1일 경우를 대비해서 넣는다. result는 집합이기에 중복 값이 들어가도 상관 없음.
- 1부터 s의 길이만큼 for문을 순회한다.
- string_zip 함수를 제작한다.
- 여기서 n은 zip할 문자열 길이를 말한다.
- 최초 비교 문자열을 n개의 개수만큼 자른다.
- 지금부터 이것은 target(비교 하려는 문자열) 이라고 부른다.
- n부터 s의 len 만큼, n을 step으로 해 range를 만든다.
- 그리고 그 range만큼 순회를 시작한다.
- 순회를 하며 현재 target과 바로 다음 오는 n개 만큼의 문자열을 비교한다.
- 같다면 연속되는 문자열이므로 count를 +1 시킨다.
- 같지 않다면 result에 target을 현재 쌓아온 count 와 함께 이어붙인다.
- 그리고 count를 1로 초기화한다.
- target을 다음 n 만큼의 문자열로 변경한다.
- 순회가 끝나면 남은 문자열을 count와 함께 이어붙이고 result를 반환한다.
- string_zip을 통해 나온 문자열의 len을 result set에 저장한다.
- string_zip 함수를 제작한다.
- 최종적으로 가장 짧은 length를 result의 min 값으로 찾아 반환한다.
시간 복잡도 (Big-O)
- O(N^2)
테스트 케이스
감사합니다.
'development > 알고리즘' 카테고리의 다른 글
[백준] 2750: 수 정렬하기 (삽입 정렬 ver) (0) | 2024.04.24 |
---|---|
[백준] 2002: 추월 (0) | 2024.04.12 |
[프로그래머스] 120812: 최빈값 (1) | 2024.03.29 |
[백준] 11047: 동전 0 (그리디) (0) | 2024.03.22 |
[프로그래머스] JadenCase 문자열 만들기 (0) | 2022.09.11 |