일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- QueryDSL 기초
- SW Expert Academy
- 경주로 건설
- 베스트엘범
- SW ExpertAcademy
- 거울 설치
- 16234번
- 수식 최대화
- 감소하는 수
- 보석 쇼핑
- 19238번
- 12869번
- 스타트 택시
- 2020 카카오 인턴십
- 1038번
- python
- 9095번
- 빛의 경로 사이클
- HTML 기초
- 15686번
- 1789번
- 백준 알고리즘
- 프로그래머스
- 17144번
- 미세먼지 안녕!
- 파이썬
- 14499번
- 12865번
- 어른 상어
- 키패드 누르기
Archives
- Today
- Total
보물창고 블로그
2018 KAKAO BLIND RECRUITMENT 3차 압축 본문
728x90
문제 링크: https://programmers.co.kr/learn/courses/30/lessons/17684
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제의 설명대로 그대로 구현하면 된다. 풀이는 아래와 같다.
dic1 = {}
for i in range(65, 91):
dic1[chr(i)] = i - 64
def solution(msg):
last = 27
answer = []
l = len(msg)
idx = 0
c = 1
while 1:
if dic1.get(msg[idx:idx + c]) is None:
dic1[msg[idx:idx + c]] = last
last += 1
answer.append(dic1[msg[idx:idx + c - 1]])
idx += c - 1
c = 1
else:
if idx + c > l:
answer.append(dic1[msg[idx:idx + c]])
break
c += 1
return answer
'알고리즘 풀이 > 프로그래머스' 카테고리의 다른 글
2020 카카오 인턴십 수식 최대화 풀이 With Python (4) | 2020.07.06 |
---|---|
2020 카카오 인턴십 키패드 누르기 풀이 With Python (0) | 2020.07.06 |
2018 KAKAO BLIND RECRUITMENT 3차 방금그곡 (0) | 2020.03.26 |
2018 KAKAO BLINDRECRUITMENT 1차 다트게임 (0) | 2020.03.26 |
2018 KAKAO BLINDRECRUITMENT 1차 비밀지도 (0) | 2020.03.26 |
Comments