트리 문제 질문드려요
248
jwk
작성한 질문수 6
0
vector<int> tree[51];
int cnt, a;
void go(int node)
{
if (tree[node].size() == 0)
{
cnt++;
return;
}
for (auto& leaf : tree[node])
{
if (m == leaf) continue;
go(leaf);
}
return;
}
int main(void)
{
ios_base::sync_with_stdio(false);
cin.tie(NULL); cout.tie(NULL);
cin >> n;
for (int i = 0; i < n; i++)
{
int tRoot;
cin >> tRoot;
if (tRoot == -1)
{
a = i;
continue;
}
tree[tRoot].push_back(i);
}
cin >> m;
if (m == a)
{
cout << 0;
return 0;
}
go(a);
cout << cnt;
return 0;
}안녕하세요
이 코드는 어떤 점에서 예외가 생겨서 틀리는 걸까요?? 혹시 루트 노드만 남았을 때가 예외일까요??
답변 1
0
안녕하세요 ㅎㅎ
이 코드는 어떤 점에서 예외가 생겨서 틀리는 걸까요?? 혹시 루트 노드만 남았을 때가 예외일까요??
>> 네 맞습니다. a -> b 라는 트리가 있고 b를 지운다고 했을 때 a만 남게 되는데 이 코드는 해당 부분을 처리하지 못합니다.
또 질문 있으시면 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다.
감사합니다.
코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의
0
16
2
문제를 고민하는 시간 관련
0
24
2
코딩살구클럽
0
36
2
코딩살구클럽 문의
0
33
2
코딩살구클럽 승인
0
34
2
DP 경우의 수 설명이 이해가 되지 않습니다.
0
33
2
3-F 채점 관련 질문
0
30
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
33
2
코딩살구클럽 승인
0
44
2
코딩살구클럽승인
0
39
3
코딩살구클럽 승인
0
51
2
3-D 관련 질문
0
35
2
코살구 회원가입 문의
0
45
2
코살구 로그인 문제
0
65
2
3-A 문제 풀이 관련 질문
0
56
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
63
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
67
2
코딩살구클럽 로그인문제
0
85
3
코딩 살구 클럽 로그인 문제
0
85
2
2-J 채점관련 질문
0
67
3
코딩 살구 클럽 Python 지원 가능 여부
0
77
1
살구클럽 아이디 없음 문제
0
76
1





