Algorithm/BOJ

BOJ] 2805. 나무 자르기

BOJ]2805.나무 자르기

 

https://www.acmicpc.net/problem/2805

 

2805번: 나무 자르기

문제 상근이는 나무 M미터가 필요하다. 근처에 나무를 구입할 곳이 모두 망해버렸기 때문에, 정부에 벌목 허가를 요청했다. 정부는 상근이네 집 근처의 나무 한 줄에 대한 벌목 허가를 내주었고, 상근이는 새로 구입한 목재절단기을 이용해서 나무를 구할것이다. 목재절단기는 다음과 같이 동작한다. 먼저, 상근이는 절단기에 높이 H를 지정해야 한다. 높이를 지정하면 톱날이 땅으로부터 H미터 위로 올라간다. 그 다음, 한 줄에 연속해있는 나무를 모두 절단해버린다. 따

www.acmicpc.net

 

이분탐색(Binary Search) 문제.

.

0부터 나무의 가장 높은 높이를 찾아서 그 사이의 값들을 전기톱의 높이로 지정해가면서 값을 구하는 과정.

이분탐색의 시작점 left와 right는 

left는 0 / right는 나무의 가장 좋은 높이로 지정.

 

1.  N개의 나무를 입력받을 때, 가장 높은 나무를 기억(max)

2. 이분탐색을 위한 범위는 0부터 max까지임.

3. 이분탐색의 시작지점 left=0  , right=max

4. 이분탐색의 내부조건은 mid 기준으로 잘랐을 때 가져갈 수 있는 나무의 합이 내가 가져가야하는 나무의 길이(M)와 비교한다,

4-1.  잘라낸 나무의 합이 M보다 작다면, mid를 왼쪽으로 이동시켜야 하므로, right의 값 조정.

4-2. 잘라낸 나무의 합이 M보다 크다면, mid를 오른쪽으로 이동시켜야 하므로, left의 값 조정.

.

.

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
41
42
43
44
package beakjoon;
 
import java.util.Scanner;
 
public class bj_2805_나무자르기 {
 
    static int N;
    static int M;
    static int[] arr;
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        //나무의 수 
        N = sc.nextInt();
        arr = new int[N];
        //가져가야하는 나무의 길이 
        M = sc.nextInt();
        int max=Integer.MIN_VALUE;
        for(int i=0; i<N; i++) {
            arr[i] = sc.nextInt();
            max = Math.max(max, arr[i]);
        }
        long left=0;
        long right = max;
        long res=0;
        
        while(left<=right) {
            long mid = (left+right)/2;
            long total =0;
            for(int i=0; i<N; i++) {
                if(mid<arr[i]) {
                    total += arr[i] - mid; 
                }
            }
            if(total >= M) {
                res=mid;
                left = mid+1;
            }
            else {
                right = mid-1;
            }
        }//end while loop
        System.out.println(res);
    }
}
http://colorscripter.com/info#e" target="_blank" style="color:#4f4f4ftext-decoration:none">Colored by Color Scripter

'Algorithm > BOJ' 카테고리의 다른 글

BOJ] 14502. 연구소  (0) 2020.01.28
BOJ] 4179. 불!  (0) 2019.10.05
BOJ] 16283. Farm  (0) 2019.10.01
BOJ] 2579. 계단오르기  (0) 2019.09.25
BOJ] 1003. 피보나치 함수  (0) 2019.09.24