오늘의 인기 글
최근 글
최근 댓글
Today
Total
01-07 01:55
관리 메뉴

우노

[Binary Search] 백준 3079번 “입국심사” Python 풀이 본문

Algorithm/Binary Search

[Binary Search] 백준 3079번 “입국심사” Python 풀이

운호(Noah) 2022. 11. 10. 18:34

문제 링크

풀이

  • m명을 심사할 수 있는 최소 시간을 찾기 위해,
  • 이분 탐색의 범위를 [0 ~ m명을 모두 심사했을 때의 가능한 최대 시간]로 잡는게 핵심입니다.
  • 자세한 알고리즘은 하단 예제 코드에 설명되어있습니다.

코드

import sys

# 심사대의 개수와 심사를 받는 인원
n, m = map(int, sys.stdin.readline().split())

# 각 심사대의 심사 시간
arr = []
for _ in range(n):
    arr.append(int(sys.stdin.readline()))

# m명을 심사할 수 있는 최소 시간을 찾기 위해 
# [0 ~ m명을 모두 심사했을 때의 가능한 최대 시간]을 start, end 범위로 설정
start, end = 0, max(arr) * m

# m명을 심사할 수 있는 최소 시간 초기화
result = max(arr) * m

while (start <= end):

    # m명을 심사할 수 있는 최소 시간을 찾기 위해, start와 end의 중간 시간을 mid로 설정
    mid = (start + end) // 2

    # mid 시간 동안 심사를 진행한다고 할 때
    # 각각의 심사대에서 심사할 수 있는 최대 인원 수를 파악한 뒤, 전체 인원을 파악
    total = 0
    for i in range(n):
        total += mid // arr[i]

    # mid 시간 동안 심사할 수 있는 전체 인원 수가 m명 이상이라면
    if (total >= m):
        # 심사 시간을 더 줄이기
        end = mid - 1
        # 현재까지의 최소 시간을 저장
        result = min(result, mid)

    # mid 시간 동안 심사할 수 있는 전체 인원 수가 m명 이하라면    
    else:
        # 심사 시간을 더 늘리기
        start = mid + 1

print(result)
Comments