inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

2-R

2-R 트리 질문있습니다

284

김재민

작성한 질문수 3

0

http://boj.kr/8cefb4955fb64d18ad353997d162cc29

제출시 77%에서 오답처리 되는데, 어느 부분이 틀렸는지 모르겠습니다.

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

c++ 코딩-테스트

답변 2

1

큰돌

안녕하세요 재민님 ㅎㅎ

지웅님이 잘 대답해주셨네요 ㅎㅎ

자식이 하난데 그 자식이 지워진 노드라면?

 

이부분이 반례인 것 같습니다.

 

감사합니다.

1

송지웅

안녕하세요 저도 큰돌님 강의를 들으며 코테 준비하고 있는 지나가던 사람입니당

57 번줄 조건문에서

if (eraes_node == 0)

0번째를 지우면 그냥 끝내버리는 걸로 되어있는데 아무래도 예제는 루트노드가 0번째에서만 있어서 그러신것같습니다 그런데 테스트 케이스에는 루트노드가 0번쨰가 아닌 경우가 있을듯 합니다

0

김재민

아 제가 실수했네요ㅎㅎ 감사합니다
근데 지적해 주신 부분을 고쳐도 77%에서 틀렸다고 합니다.

1

송지웅

눈 코딩 했었어서 제일 먼저 보인 문제만 댓글달고 갔었는데 오늘 알림이 와있어서 제대로 쭉 보았습니다.

재민님 코드에서 dfs가 실행되었을때 현재노드에서 사이즈가 없을때 그것을 리프노드로 간주하고 ++ 하는 구조인데요.

그 사이즈가 1 (자식이 한명인데) 막상 그 자식이 지워진 노드다.

이 경우에 그 부모노드가 리프노드가 되어야되는데 이미 사이즈가 있는거로 간주되어 if문을 무시하고 넘어갑니다 ! 그래서

포문으로 자식노드들을 탐색할때 그거에대한 처리가 필요해 보입니다.

for (auto &c_node : a[p_node])

{

if (c_node == eraes_node) {

//자식이 하난데 그 자식이 지워진 노드라면?

if (a[p_node].size() == 1 && c_node == a[p_node][0]) {

//부모가 리프노드가 되어버리

leaf_node++;

}

continue;

}

dfs(c_node);

}

이렇게 해당 부분에 대한 처리를 하면 됩니다

코딩살구클럽 승인

0

15

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

27

2

3-F 채점 관련 질문

0

22

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

26

2

코딩살구클럽 승인

0

40

2

코딩살구클럽승인

0

32

3

코딩살구클럽 승인

0

47

2

3-D 관련 질문

0

34

2

코살구 회원가입 문의

0

42

2

코살구 로그인 문제

0

64

2

3-A 문제 풀이 관련 질문

0

53

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

61

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

64

2

코딩살구클럽 로그인문제

0

76

3

코딩 살구 클럽 로그인 문제

0

82

2

2-J 채점관련 질문

0

65

3

코딩 살구 클럽 Python 지원 가능 여부

0

77

1

살구클럽 아이디 없음 문제

0

76

1

1-O 코딩살구클럽 채점관련 질문

0

60

2

히든 테스트 케이스가 사라졌습니다

0

57

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

74

2

살구 클럽 채점 관련 문의(테스트 케이스)

0

66

2