[프로그래머스, 43238] 입국심사 (java)
Problem Solving/Programmers

[프로그래머스, 43238] 입국심사 (java)

728x90

https://school.programmers.co.kr/learn/courses/30/lessons/43238

 

프로그래머스

SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프

programmers.co.kr


메모리: 82.5 MB, 시간: 45.28 ms

사용 알고리즘: 이분탐색

class Solution {
    public long solution(int n, int[] times) {
        
        long answer = Long.MAX_VALUE;
        
        // 이분탐색
        long s = 0, e = Long.MAX_VALUE, m;
        long count;
        while(s <= e) {
            m = (s + e) / 2;
            
            // m 시간 안에 입국 심사를 끝낼 수 있는지 확인
            count = 0;
            for(int i = 0; i < times.length; i++) {
                count += m / times[i];
                if(count >= n) break;
            }
            
            if(count >= n) { // m 시간 안에 입국 심사를 끝낼 수 있다면
                answer = m;
                e = m - 1; // 더 짧은 시간 안에 끝낼 수 있는지 확인
            }
            else // m 시간 안에 입국 심사를 끝낼 수 없다면
                s = m + 1; // 더 긴 시간 안에 끝낼 수 있는지 확인
        }
        
        return answer;
    }
}
728x90