https://school.programmers.co.kr/learn/courses/30/lessons/43238
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
이 문제는 이분탐색문제였다.
이분탐색 알고리즘이 낯설어서 고민을 많이 했다.
알고보니 걸리시간을 기준으로 이분탐색을 하면되는 문제!
def solution(n, times):
answer = 0
left = min(times)
right = max(times) * n
mid = (left + right) // 2
while left <= right:
mid = (left + right) // 2
person = 0
for time in times:
person += (mid // time)
if person >= n:
answer = mid
right = mid - 1
else:
left = mid + 1
return answer
아래는 답을 도출해나가는 과정을 정리한 것이다. 다음에는 깔끔하게 정리해서 첨부해야지.


'👩💻 코테 공부 > 코테 공부' 카테고리의 다른 글
| [코테 - py] 소수 찾기 (0) | 2024.08.11 |
|---|---|
| [코테 - py] 징검다리 (0) | 2024.08.11 |
| [코테 - py] 가장 큰 수 (0) | 2024.08.03 |
| [코테 - py] 최대 힙 (0) | 2024.07.31 |
| [코테 - py] 최소 힙 (0) | 2024.07.31 |