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
- 1단계
- 딥러닝
- 파이썬
- docker
- Object detection
- 자료구조 및 실습
- SWEA
- C++
- ubuntu
- pytorch
- 이것이 코딩테스트다 with 파이썬
- test-helper
- AWS
- 전산기초
- 코드수행
- 백준
- 3단계
- 모두를 위한 딥러닝 강좌 시즌1
- CS231n
- cs
- 구현
- ssd
- 실전알고리즘
- 머신러닝
- 그리디
- 프로그래머스
- MySQL
- STL
- Python
- 2단계
Archives
- Today
- Total
곰퓨타의 SW 이야기
[프로그래머스 level3 입국심사] 이분 탐색 활용하기 본문
해결해야하는 문제는 다음과 같았다.
https://programmers.co.kr/learn/courses/30/lessons/43238
코딩테스트 연습 - 입국심사
n명이 입국심사를 위해 줄을 서서 기다리고 있습니다. 각 입국심사대에 있는 심사관마다 심사하는데 걸리는 시간은 다릅니다. 처음에 모든 심사대는 비어있습니다. 한 심사대에서는 동시에 한
programmers.co.kr
처음에 문제를 접하였을 때에는, 이분 탐색이라고 적혀있었지만 자연수의 분할이 떠올랐다.
입국장의 개수만큼 사람 수를 분할하여, 가장 큰 시간이 걸리는 입국장과, 가장 적은 시간이 걸리는 입국장의 차이가 가장 작다면, 그때가 가장 최단 시간이 걸리는 경우라고 생각하였다. 하지만 이는 생각이 매우 짧았던 것이었다.
from itertools import combinations_with_replacement
def DIVID(n,m):
A=[list(x) for x in combinations_with_replacement(range(1,n),m) if sum(x)==n]
return A
def solution(n, times):
answer = 0
num_divids = DIVID(n,len(times))
dif_time = int(1e9)
times.sort(reverse=True)
for num_divid in num_divids :
time_list = []
for i in range(len(times)):
time_list.append(times[i]*num_divid[i])
if max(time_list) - min(time_list) < dif_time :
dif_time = max(time_list) - min(time_list)
answer = max(time_list)
return answer
따라서 이분 탐색이라는 키워드에 맞게 어떤 방식으로 하는 것이 좋을지 아이패드에 계속 끄적여봤다.
def solution(n, times):
answer = 0
left = 1
right = max(times) * n
while left <= right:
mid = (left + right) // 2
count = 0
for time in times:
count += mid // time
if count >= n:
answer = mid
right = mid - 1
break
else :
left = mid + 1
return answer
이 문제는
- 입국심사를 기다리는 사람은 1명 이상 1,000,000,000명 이하입니다.
- 각 심사관이 한 명을 심사하는데 걸리는 시간은 1분 이상 1,000,000,000분 이하입니다.
- 심사관은 1명 이상 100,000명 이하입니다.
조건이 굉장히 큰 수들이다.
효율적으로 코드를 작성해야 할때, 이분탐색 알고리즘이 많이 사용된다는 것을 알 수 있었다.
'TIL > 프로그래머스' 카테고리의 다른 글
[프로그래머스 level3 정수 삼각형] 다이나믹 프로그래밍 사용하기 (0) | 2021.06.16 |
---|---|
[프로그래머스 level3 가장 먼 노드] 시간초과 극복하기 (0) | 2021.06.15 |
[프로그래머스 level3 N으로 표현] 문제를 넓게 바라보기 (0) | 2021.06.14 |
[프로그래머스 level2 DATETIME에서 DATE로 형 변환] DATE_FORMAT 활용하기2 (0) | 2021.06.14 |
[프로그래머스 level2 입양 시각 구하기(1)] DATE_FORMAT 활용하기 (0) | 2021.06.14 |
Comments