반응형
Notice
Recent Posts
Recent Comments
Link
«   2025/01   »
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
Archives
Today
Total
01-22 13:27
관리 메뉴

ImJay

[BOJ/Java] 2961. 도영이가 만든 맛있는 음식 본문

알고리즘/BOJ - Java

[BOJ/Java] 2961. 도영이가 만든 맛있는 음식

ImJay 2024. 2. 4. 16:51
반응형

[BOJ/Java] 2961. 도영이가 만든 맛있는 음식

 

2961번: 도영이가 만든 맛있는 음식

첫째 줄에 재료의 개수 N(1 ≤ N ≤ 10)이 주어진다. 다음 N개 줄에는 그 재료의 신맛과 쓴맛이 공백으로 구분되어 주어진다. 모든 재료를 사용해서 요리를 만들었을 때, 그 요리의 신맛과 쓴맛은

www.acmicpc.net


풀이

package edu.ssafy.im.BOJ.S2.No2961;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

public class Main {
    static int[] s, b; // 각 재료의 신맛과 쓴맛을 저장하는 배열
    static int ans; // 결과값을 저장할 변수

    public static void main(String[] args) throws NumberFormatException, IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringBuilder sb = new StringBuilder();
        int n = Integer.parseInt(br.readLine()); // 재료의 개수 입력 받기
        s = new int[n]; // 신맛을 저장할 배열 초기화
        b = new int[n]; // 쓴맛을 저장할 배열 초기화
        for (int i = 0; i < n; i++) {
            // 각 재료의 신맛과 쓴맛 입력 받기
            String input = br.readLine();
            StringTokenizer st = new StringTokenizer(input);
            s[i] = Integer.parseInt(st.nextToken());
            b[i] = Integer.parseInt(st.nextToken());
        }
        ans = Integer.MAX_VALUE; // 결과값 초기화
        powerSet(0, new boolean[n]); // 부분집합 구하기
        sb.append(ans); // 결과값 출력을 위한 문자열에 추가
        System.out.println(sb); // 결과 출력
    }

    private static void powerSet(int i, boolean[] v) {
        // basis part
        if(i == v.length) { // 모든 재료를 선택했을 때
            int ss = 1, bs = 0, c = 0; // 각각 신맛과 쓴맛, 미사용된 재료의 개수를 저장할 변수
            for (int j = 0; j < v.length; j++) {
                if(v[j]) { // 현재 재료를 사용했을 때
                    ss *= s[j]; // 신맛에 현재 재료의 신맛을 곱함
                    bs += b[j]; // 쓴맛에 현재 재료의 쓴맛을 더함
                } else {
                    c++; // 미사용된 재료의 개수 증가
                }
            }
            if(c != v.length) { // 모든 재료를 사용한 경우가 아닐 때
                ans = Math.min(ans, Math.abs(ss - bs)); // 현재까지의 결과값 갱신
            }
            return;
        }

        // inductive part
        // 현재 재료를 사용하는 경우와 사용하지 않는 경우를 모두 탐색
        v[i] = true; // 현재 재료를 사용하는 경우
        powerSet(i + 1, v); // 다음 재료로 넘어감
        v[i] = false; // 현재 재료를 사용하지 않는 경우
        powerSet(i + 1, v); // 다음 재료로 넘어감
    }
}

 

반응형
Comments