[백준 / 실버2] 1182 부분수열의 합 (Java)

Ilhwanee·2022년 12월 2일
0

코딩테스트

목록 보기
129/155

문제 보기



사용한 것

  • 모든 부분수열의 합을 구하기 위한 DFS


풀이 방법

  • DFS로 모든 부분수열의 합을 구한다.
    • 해당 인덱스 숫자를 선택하거나 선택하지 않고 재귀 호출
    • 모든 숫자 완료 -> 합이 s와 같으면 answer 증가
  • flag를 사용하여 공집합인 경우 answer을 증가시키지 않는다.


코드

public class Main {

    private static int n;
    private static int s;
    private static int[] arr;
    private static int answer = 0;
    private static boolean flag = false;

    public static void main(String[] args) throws IOException {
        // 초기화
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String[] line = br.readLine().split(" ");
        n = Integer.parseInt(line[0]);
        s = Integer.parseInt(line[1]);
        arr = new int[n];
        StringTokenizer st = new StringTokenizer(br.readLine());
        for (int i = 0; i < n; i++) {
            arr[i] = Integer.parseInt(st.nextToken());
        }

        // DFS (flag는 공집합을 제외하기 위해)
        dfs(0, 0, false);

        System.out.println(answer);
    }

    private static void dfs(int depth, int sum, boolean flag) {
        if (depth == n) {
            if (flag && sum == s) {
                answer++;
            }
            return;
        }

        dfs(depth + 1, sum, flag); // 선택 X
        dfs(depth + 1, sum + arr[depth], true); // 선택 O
    }
}


profile
블로그 이전 -> https://pppp0722.github.io

0개의 댓글