boolean flag의 유무
761
작성한 질문수 27
안녕하세요. 문제를 다시 풀던 와중에 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 변수를 쓰는게 좋습니다. 이 문제는 제가 데이터를 작게 넣어서 그렇지 실전에서는 중요할 수 있습니다.
안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.
1
86
3
갑자기 채점 사이트가 바뀌었어요
0
57
1
문제 리스트 페이지
0
44
1
채점 사이트 관련 질문드립니다
0
42
1
봉우리 문제 질문입니다
0
104
2
씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?
0
77
0
이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?
0
83
0
가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법
0
77
1
좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ
0
96
2
6-7 강의에서
0
56
1
6-6. 장난꾸러기 질문 있습니다.
0
55
1
강의 수강후 코딩테스트
0
127
1
answer 변수 사용 여부
0
51
1
2중 for문
1
99
2
2-11. 임시반장정하기 (Runtime Error)
0
69
1
혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?
0
76
1
이런 풀이는 어떨까요
0
52
1
자바 스트림 방식의 효율성 질문 드립니다.
0
65
1
알고리즘 자료 구조들..
0
70
1
StringBuilder vs BufferdWriter
0
53
1
원더랜드(프림)
0
58
1
이런 코드는 어떤가요?
0
68
1
bfs 풀이
0
66
1
병합정렬
0
58
1





