<Algorithm> 87. 2512번 예산
by BFine반응형
1. 2512번 예산
이문제를 풀면서 이분탐색에 대한 나의 생각의 문제점을 발견 할 수 있었다.
이분탐색은 반을 나누어 대소비교를 통해 1/2 1/4 씩 줄어드는 것인데 1/2 나눠진 것이 또 돌아간다고 생각했다.
풀이를 해보면 간단하지만 접근하는 방법이 그리 간단하지는 않은 문제라고 생각한다.
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 32 33 34 35 36 37 38 39 40 | import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.StringTokenizer; public class Main { public static void main(String[] args) throws NumberFormatException, IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int n = Integer.parseInt(br.readLine()); StringTokenizer st = new StringTokenizer(br.readLine()); int[] bgt = new int[n]; int end = -1; int start = 0; for (int i = 0; i < n; i++) { bgt[i] = Integer.parseInt(st.nextToken()); end = Math.max(end,bgt[i]); } int lim = Integer.parseInt(br.readLine()); while(start<=end) { int total = 0; int mid = (start+end)/2; for(int i = 0; i < n; i++) { total += Math.min(bgt[i], mid); } if(total <= lim) { start = mid + 1; }else { end = mid - 1; } } System.out.println(start-1); } } | cs |
참고 & 출처
반응형
'공부(2018~2019) - 스킨변경전 > Algorithm' 카테고리의 다른 글
<Algorithm> 89. twosum(LeetCode) (0) | 2019.01.18 |
---|---|
<Algorithm> 88. 카펫(프로그래머스) (0) | 2019.01.15 |
<Algorithm> 86. 1766번 문제집 (0) | 2018.10.27 |
<Algorithm> 85. 15683번 감시 (0) | 2018.10.18 |
<Algorithm> 84. 14889번 스타트와 링크 (0) | 2018.10.11 |
블로그의 정보
57개월 BackEnd
BFine