inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C언어 (부록)

17.17 이진 탐색 트리 구현하기 ​

19:20 부분에서 질문있습니다.

해결된 질문

282

thd2tn

작성한 질문수 27

0

교수님께서 Seekitem()를 이용해서 pair를 return하는 방법에는 while문을 사용하는 방법 말고도 재귀호출을 사용하는 방법도 있다고 하셨습니다.

저는 재귀호출로 짜봤는데 아무래도 너무 지저분한 거 같습니다. 교수님이나 다른 분이 재귀호출을 사용하셨다면 어떤 식으로 코드를 짰을 지가 궁금합니다.

제가 짠 코드는 아래와 같습니다.

static Node* SeekParentNode(const Item* pi, Node* pnode)

{

if (pnode->left != NULL)

if (compare(pnode->left->item, *pi) == 0)

return pnode;

 

if (pnode->right != NULL)

if (compare(pnode->right->item, *pi) == 0)

return pnode;

 

if (compare(pnode->item, *pi) > 0)

{

if (pnode->left == NULL && pnode->right == NULL)

return NULL;

SeekParentNode(pi, pnode->left);

}

else if (compare(pnode->item, *pi) < 0)

{

if (pnode->left == NULL && pnode->right == NULL)

return NULL;

SeekParentNode(pi, pnode->right);

}

}

 

static Node* SeekChildNode(const Item* pi, Node* pnode)

{

if (compare(pnode->item, *pi) == 0)

return pnode;

 

if (compare(pnode->item, *pi) > 0)

{

if (pnode->left == NULL)

return NULL;

SeekChildNode(pi, pnode->left);

}

else

{

if (pnode->right == NULL)

return NULL;

SeekChildNode(pi, pnode->right);

}

}

 

static Pair SeekItem(const Item* pi, const Tree* ptree)

{

Pair found_pair;

found_pair.parent = SeekParentNode(pi, ptree->root);

found_pair.child = SeekChildNode(pi, ptree->root);

 

return found_pair;

}

c

답변 1

1

강민철

작성해주신 코드도 정말 좋은 듯 합니다 :)

수업노선자료파일 다운

0

12

1

C언어에서

0

28

1

포인터 질문

0

34

2

sizeof는 컴파일 타임 연산자라서 CPU를 사용치 않는다

0

22

2

실기 공부 시작 하려고 하는데요

0

61

2

20년 4,5회 13번

0

39

2

이진 탐색: 탐색 실패하는 경우 어째서 first > last인 경우가 나오나요?

0

332

1

17.12) access violation

0

315

1

finditembyindex 질문드립니다!

0

351

1

pnode = pnode->next; 와 pnode->next = pnode;는 같은 것으로 생각해도 될까요?

0

409

2

질문. warning뜨는 이유

0

304

1

링크드 리스트 질문 드립니다.

0

217

1

함수포인터 질문드립니다

0

231

1

강의 내용 질문 드립니다!

0

377

2

노드 주소 순서 관련 질문

0

284

1

질문드립니다!

0

244

1

DeleteAllNodes 에서 질문있습니다.

0

389

5

16:30 질문입니다.

0

351

4

scanf 질문이요!!

0

255

1

12:30 의 ArrayQueue.h

0

297

2

10:10 Add front에서 질문드립니다.

1

364

1

스택 자료구조

0

252

1

변수 count의 활용에 대해 질문이 있습니다.

0

323

1

1번 실행하면 에러가 뜨는데 이유를 모르겠습니다..

0

373

2