[ALGORITHM]PROGRAMMERS/Greedy-저울

문제

하나의 양팔 저울을 이용하여 물건의 무게를 측정하려고 합니다. 이 저울의 양팔의 끝에는 물건이나 추를 올려놓는 접시가 달려 있고, 양팔의 길이는 같습니다. 또한, 저울의 한쪽에는 저울추들만 놓을 수 있고, 다른 쪽에는 무게를 측정하려는 물건만 올려놓을 수 있습니다.

image0.png

저울추가 담긴 배열 weight가 매개변수로 주어질 때, 이 추들로 측정할 수 없는 양의 정수 무게 중 최솟값을 return 하도록 solution 함수를 작성해주세요.

예를 들어, 무게가 각각 [3, 1, 6, 2, 7, 30, 1]인 7개의 저울추를 주어졌을 때, 이 추들로 측정할 수 없는 양의 정수 무게 중 최솟값은 21입니다.

제한 사항
  • 저울추의 개수는 1개 이상 10,000개 이하입니다.
  • 각 추의 무게는 1 이상 1,000,000 이하입니다.
입출력 예
weight return
[3, 1, 6, 2, 7, 30, 1] 21
입출력 예 설명

문제에 나온 예와 같습니다.

코드

import java.util.*;
class Solution {
    public int solution(int[] weight) {
         Arrays.sort(weight);
        int answer = 1;
        for (int i = 0; i < weight.length; i++){
            if (answer < weight[i]) break;
            answer+= weight[i];
        }
        return answer;
    }
}
  • 먼저 입력된 배열을 정렬한다.

    그러면 [1, 1, 2, 3, 6, 7, 30]이 된다.

  • 6까지 탐색을 했다치면 1+1+2+3+6=13까지 무게를 잴 수 있다.

    그리고 이 추들로 13까지 모두 만들어 낼 수 있다.

    [1, 2, 2+1, 1+1+2, 2+3, 6, 6+1, 2+6, 3+6, 1+1+2+6,,,,,,,]이런식으로.

  • 즉, 따라서 값을 누적한 값이 현재 추보다 작은 경우 그 누적값이 정답이 된다.

추들의 무게의 합 + 1 = 추들이 측정할 수 없는 최소 무게

느낀점

저번에 풀었던 문제여서 개쉽게 풀었다. 10초컷은 구라~

문제 : https://programmers.co.kr/learn/courses/30/lessons/42886

저장소 : https://github.com/yoo-chaewon/HELLO_JAVA/blob/master/Algorithm/2.PROGRAMMERS/with%20Study/Greedy_저울.java