algorithm/baekjoon

[BOJ] 2343 기타 레슨 (Java)

올빼밋. 2023. 1. 31. 14:28
728x90

# 출처 : https://www.acmicpc.net/problem/2343

 

2343번: 기타 레슨

강토는 자신의 기타 강의 동영상을 블루레이로 만들어 판매하려고 한다. 블루레이에는 총 N개의 강의가 들어가는데, 블루레이를 녹화할 때, 강의의 순서가 바뀌면 안 된다. 순서가 뒤바뀌는 경

www.acmicpc.net


# 풀이

 

이분 탐색으로 푸는 문제라고 했는데, 코드를 계속 지저분하게 짜서 결국 사람들 코드를 참고했다.

근데 이번 이분 탐색은 인덱스가 기준으로 나누기 2를 하는 것이 아니라 값을 나누어 비교하는 식으로 결과를 도출했다.

디버깅하면서 하나하나 따라가니 결국은 정답으로 가는걸 봤지만,

어떻게 전체 값과 해당 배열의 최대값으로 해당 문제 풀이로 초래했는지 아직까지 의문이다.


# 코드

import java.io.*;
import java.util.Arrays;

public class Main {
    public static void main(String[] args) {
        try {
            BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
            int[] input = Arrays.stream(br.readLine().split(" ")).mapToInt(Integer::parseInt).toArray();
            int N=input[0], M=input[1];
            int[] data = Arrays.stream(br.readLine().split(" ")).mapToInt(Integer::parseInt).toArray();

            // 누적값 미리 계산
            int sumValue = 0, maxValue = 0;
            for(int i=0; i<N; i++){
                sumValue += data[i];
                maxValue = Math.max(maxValue, data[i]);
            }

            // 이분 탐색
            while(maxValue <= sumValue) {
                int count = 0, tempSum = 0;
                int mid = (maxValue + sumValue) / 2;

                for(int i=0; i<N; i++){
                    if(tempSum + data[i] > mid){
                        tempSum = 0;
                        count += 1;
                    }
                    tempSum += data[i];
                }

                if(tempSum !=0) count += 1;
                if(count <= M) {
                    sumValue = mid - 1;
                }else{
                    maxValue = mid + 1;
                }
            }

            System.out.println(maxValue);
        } catch (Exception e) {
            System.out.println(e);
        }
    }
}
728x90