작성
·
275
0
안녕하세요 큰돌님!
2-R에서 선생님께서는 child라는 변수를 만들어 기저사례를 정하셨는데 저는 a[here].size() 즉 배열의 크기가 0이면 return 1을 하도록 기저사례를 정의했습니다.
그렇게 했더니 틀렸습니다가 뜨더군요ㅠㅠㅠ 배열의 크기로 확인하면 안되는 걸까요..?
#include <bits/stdc++.h>
using namespace std;
vector<int> a[54];
int n, tmp, del, root;
int dfs(int here) {
int ret = 0;
//이 부분입니다!
if(a[here].size() == 0) return 1;
for(int there : a[here]) {
if(there == del) continue;
ret += dfs(there);
}
return ret;
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(0);
cin >> n;
for(int i = 0; i < n; i++) {
cin >> tmp;
if(tmp == -1) root = i;
else a[tmp].push_back(i);
}
cin >> del;
if(del == root) {
cout << 0 << "\n";
return 0;
}
cout << dfs(root) << "\n";
return 0;
}
답변 1
0
안녕하세요 성종님 ㅎㅎ
그니까 성종님 말씀은.
int dfs(int here) {
int ret = 0;
//이 부분입니다!
if(a[here].size() == 0) return 1;
for(int there : a[here]) {
if(there == del) continue;
ret += dfs(there);
}
return ret;
}
앞의 코드도 되어야 하지 않냐. 는 말씀이시죠?
자, 저 코드를 해석해볼게요.
만약 이 here 의 "이어진노드"가 하나도 없다면 리프노드이기 때문에 1을 리턴하고
그게 아니라면, 지워진 노드를 제외하고 자식노드를 모두 더해 return ret을 리턴한다는 것입니다.
하지만 이렇게 되면, 이 경우를 체크하지 못합니다.
1 >>> 2
이렇게 1과 2만 연결된 상태에서 2를 지운다고 하면 1은 리프노드가 되겠죠?
근데 저 코드는 1에는 2가 연결된 상태기 때문에 성종님이 작성하신
here 의 "이어진노드"가 하나도 없다면 리프노드이기 때문에 1을 리턴하고
부분에 걸리지가 않습니다. 즉, 원하는 결과가 나오지 않게 됩니다.
그렇기 때문에 틀린 거 같습니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제가 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
아하 그런거였군요! 답변 감사합니다 :)