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
- 백준
- java
- Kotlin
- 백준 17779
- MySQL
- 백준 17626
- with recursive
- 백준 16235
- Spring
- Spring Boot
- 프로래머스
- MSA
- spring cloud
- spring security
- 백준 16719
- 웹어플리케이션 서버
- 프로그래머스
- Coroutine
- JPA
- spring oauth
- 파이썬
- sql 기술면접
- 백준 16236
- 백준 19238
- java 기술면접
- JVM
- 백준 파이썬
- re.split
- 백준 15685
- springboot
Archives
- Today
- Total
시작이 반
[프로그래머스] 보석 쇼핑(python 파이썬) 본문
SMALL
programmers.co.kr/learn/courses/30/lessons/67258
모든 보석을 포함하는 최소 구간을 구하는 문제이다.
우선 모든 구간이기 때문에 안될걸 알지만 생각나는 방법이 없어서
nC2를 이용하여 모든 구간을 구하여 풀었다.
gems 배열의 크기는 1 이상 100,000 이하이다
100000C2를 하면 50억(?)정도 나온다...
조합으로 푼 코드
import math
min_result = list()
min_range = math.inf
def solution(gems):
gems_kind = set(gems)
if len(gems_kind) == 1:
return [1, 1]
visited = [False] * len(gems)
combination(visited, 0, 0, len(gems_kind), gems)
answer = list()
while min_result:
x, y = min_result.pop()
if y - x == min_range:
answer.append([x + 1, y + 1])
answer.sort()
return answer[0]
def combination(visited: list, s, depth, gems_kind, gems):
global min_range
if depth == 2:
s_e = list()
for i in range(len(visited)):
if visited[i]:
s_e.append(i)
if len(set(gems[s_e[0]: s_e[1] + 1])) == gems_kind:
if min_range >= s_e[1] - s_e[0]:
min_range = s_e[1] - s_e[0]
min_result.append([s_e[0], s_e[1]])
return
for i in range(s, len(visited)):
if visited[i]:
continue
visited[i] = True
combination(visited, i, depth + 1, gems_kind, gems)
visited[i] = False
해결 방법이 떠오르지 않아 답을 봤다.
2개의 포인터를 사용하고
포인터를 움직이면서
포인터의 사이에 사전을 이용하여 사전의 길이와 보석를 확인하며 푼다.
정식 문제 해설
풀이를 보니 어려운문제는 아니지만 처음 접하는 유형이었다..
def solution(gems):
gems_kind = set(gems)
if len(gems_kind) == 1:
return [1, 1]
lp, rp = 0, 0
answer = [1, len(gems)]
gems_dict = dict()
gems_dict[gems[0]] = 1
while lp < len(gems) and rp < len(gems):
if len(gems_dict) == len(gems_kind):
if answer[1] - answer[0] > rp - lp:
answer = [lp+1, rp+1]
if gems_dict[gems[lp]] != 1:
gems_dict[gems[lp]] -= 1
else:
del gems_dict[gems[lp]]
lp += 1
else:
rp += 1
if rp >= len(gems):
break
if not gems[rp] in gems_dict:
gems_dict[gems[rp]] = 1
else:
gems_dict[gems[rp]] += 1
return answer
LIST
'알고리즘 > Programmers' 카테고리의 다른 글
[프로그래머스] 오픈채팅방 (Java 자바) (0) | 2021.08.19 |
---|---|
[프로그래머스] 문자열 압축 (Java 자바) (0) | 2021.08.19 |
[프로그래머스] 수식 최대화(python 파이썬) (0) | 2021.04.29 |
[프로그래머스] 키패드 누르기(python 파이썬) (0) | 2021.04.29 |
[프로그래머스] 순위 검색(python 파이썬) (2) | 2021.03.19 |