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;
}
回答 1
안녕하세요. 계속 프로젝트를 해야지 하다가 결제하고 환경 설정 중입니다.
0
14
1
Export template 안됨
1
26
2
scanf("%d\n") 의미
0
20
1
필기자료 사라졌나요?(실기 일주일만에 안돼서 재도전-_-)
0
37
2
26년 1회 실기 해설 강의
0
51
2
주소 연산자(&) 간접 지정자(*) 반대 개념
0
33
1
이진 탐색: 탐색 실패하는 경우 어째서 first > last인 경우가 나오나요?
0
324
1
17.12) access violation
0
307
1
finditembyindex 질문드립니다!
0
348
1
pnode = pnode->next; 와 pnode->next = pnode;는 같은 것으로 생각해도 될까요?
0
401
2
질문. warning뜨는 이유
0
301
1
링크드 리스트 질문 드립니다.
0
216
1
함수포인터 질문드립니다
0
224
1
강의 내용 질문 드립니다!
0
369
2
노드 주소 순서 관련 질문
0
282
1
질문드립니다!
0
242
1
DeleteAllNodes 에서 질문있습니다.
0
375
5
16:30 질문입니다.
0
343
4
scanf 질문이요!!
0
253
1
12:30 의 ArrayQueue.h
0
292
2
10:10 Add front에서 질문드립니다.
1
362
1
스택 자료구조
0
246
1
변수 count의 활용에 대해 질문이 있습니다.
0
320
1
1번 실행하면 에러가 뜨는데 이유를 모르겠습니다..
0
371
2

