인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

김동현님의 프로필 이미지

작성한 질문수

자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비

1. 합이 같은 부분집합

boolean flag의 유무

작성

·

707

0

안녕하세요. 문제를 다시 풀던 와중에  flag 없이 아래와 같이 작성해도 정답이 인정되었습니다. 혹시 변수 flag가 중요한 역할을 하는 것이 있나요? 아니면 없이 아래 코드처럼 작성해도 될까요?




import java.util.Scanner;

public class Practice {
static String answer = "NO";
static int n, total = 0;


public String DFS(int lv, int sum, int[] arr){

if(lv == n){
if(total - sum == sum){
return answer = "YES";
}
}
else{
BFS(lv + 1, sum+ arr[lv], arr);
BFS(lv + 1, sum, arr); /
}
return "NO";
}

public static void main(String[] args) {
Practice t = new Practice();
Scanner kb = new Scanner(System.in);
n = kb.nextInt();
int[] arr = new int[n];
for(int i =0; i < n; i++){
arr[i] = kb.nextInt();
total += arr[i];
}
t.DFS(0, 0, arr);
System.out.println(answer);
}
}




답변 1

0

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

답을 찾았으면 스택에 남아있는 재귀들은 호출되자마자 바로 끝나게끔 flag 변수를 쓰는게 좋습니다. 이 문제는 제가 데이터를 작게 넣어서 그렇지 실전에서는 중요할 수 있습니다.