๐Ÿ’ก Algorithm

[Java] ๋„์˜์ด๊ฐ€ ๋งŒ๋“  ๋ง›์žˆ๋Š” ์Œ์‹ - ๋ฐฑํŠธ๋ž˜ํ‚น (Lv. Sliver2)

jcowwk 2025. 2. 10. 15:50

๋„์˜์ด๊ฐ€ ๋งŒ๋“  ๋ง›์žˆ๋Š” ์Œ์‹ - ๋ฐฑํŠธ๋ž˜ํ‚น


1. ๋ฌธ์ œ

2. ํ’€์ด


1. ๋ฌธ์ œ

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

 

2. ํ’€์ด

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

public class Main {
    static int N;
    static int[][] ingre;
    static int answer = Integer.MAX_VALUE;

    public static void favor(int i, int S, int B, int cnt) {
        if (i == N) {
            if (cnt == 0) return;
            int result = Math.abs(S - B);
            answer = Math.min(answer, result);
            return;
        }

        favor(i + 1, S * ingre[i][0], B + ingre[i][1], cnt + 1);
        favor(i + 1, S, B, cnt);
    }

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        N = Integer.parseInt(br.readLine());
        ingre = new int[N][2];

        for (int i = 0; i < N; i++) {
            StringTokenizer st = new StringTokenizer(br.readLine());
            ingre[i][0] = Integer.parseInt(st.nextToken()); 
            ingre[i][1] = Integer.parseInt(st.nextToken()); 
        }

        favor(0, 1, 0, 0);
        System.out.println(answer);
    }
}

 

์ตœ์ ํ™”๋ฅผ ์œ„ํ•ด์„œ ์žฌ๊ท€๋ฅผ ์‚ฌ์šฉํ–ˆ์Šต๋‹ˆ๋‹ค.

if๋ฌธ์œผ๋กœ ๋ถˆํ•„์š”ํ•œ ๊ณ„์‚ฐ์„ ์ค„์—ฌ์ฃผ์—ˆ์Šต๋‹ˆ๋‹ค.


๋ฌธ์ œ๊ฐ€ ์žˆ์œผ๋ฉด ๋Œ“๊ธ€ ๋‚จ๊ฒจ์ฃผ์„ธ์š” !

ํ”ผ๋“œ๋ฐฑ์€ ์–ธ์ œ๋‚˜ ํ™˜์˜์ž…๋‹ˆ๋‹ค <3