inflearn logo
강의

Course

Instructor

Hong Jung-mo's C Programming: Learning by Doing (Appendix)

17.17 Implementing a Binary Search Tree ​

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

Resolved

285

thd2tn

27 asked

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

Answer 1

1

kangminchul

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

26년 1회차 기출 강의

0

20

2

기출문제

0

43

1

정보처리기사 실기 zip

0

37

2

데이터베이스 노션

0

34

2

수업노선자료파일 다운

0

32

2

C언어에서

0

48

1

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

0

336

1

17.12) access violation

0

319

1

finditembyindex 질문드립니다!

0

353

1

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

0

411

2

질문. warning뜨는 이유

0

305

1

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

0

218

1

함수포인터 질문드립니다

0

233

1

강의 내용 질문 드립니다!

0

381

2

노드 주소 순서 관련 질문

0

286

1

질문드립니다!

0

246

1

DeleteAllNodes 에서 질문있습니다.

0

395

5

16:30 질문입니다.

0

357

4

scanf 질문이요!!

0

258

1

12:30 의 ArrayQueue.h

0

299

2

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

1

368

1

스택 자료구조

0

254

1

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

0

327

1

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

0

377

2