inflearn logo
강의

講義

知識共有

ホン・ジョンモのついていきながら学ぶC言語(付録)

17.17 バイナリナビゲーションツリーの実装

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

解決済みの質問

289

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

kangminchul

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

리눅스로 진행해도 될까요?

0

20

2

26년 1회차 기출 강의

0

54

2

기출문제

0

55

1

정보처리기사 실기 zip

0

44

2

데이터베이스 노션

0

38

2

수업노선자료파일 다운

0

34

2

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

0

337

1

17.12) access violation

0

319

1

finditembyindex 질문드립니다!

0

354

1

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

0

411

2

질문. warning뜨는 이유

0

307

1

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

0

220

1

함수포인터 질문드립니다

0

234

1

강의 내용 질문 드립니다!

0

384

2

노드 주소 순서 관련 질문

0

289

1

질문드립니다!

0

249

1

DeleteAllNodes 에서 질문있습니다.

0

398

5

16:30 질문입니다.

0

358

4

scanf 질문이요!!

0

258

1

12:30 의 ArrayQueue.h

0

300

2

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

1

369

1

스택 자료구조

0

256

1

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

0

327

1

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

0

379

2