Hong Jung-mo's C Programming: Learning by Doing (Appendix)
17.17 Implementing a Binary Search Tree
19:20 부분에서 질문있습니다.
교수님께서 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;
}
Answer 1
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

