《대화데이터구조》 독서노트(二)
트리(Tree)는 n(n>=0)개의 결점의 유한 집합이다.n=0일 때 빈 나무라고 부른다.비어 있지 않은 모든 트리에서 다음을 수행합니다.
1) 뿌리(Root)라는 특정한 결점이 있고 하나만 있음.
2) n>1일 경우 나머지 결점은 m(m>0)개의 서로 교차하지 않는 유한 집합 T1, T2,......,Tm로 나눌 수 있는데 그 중에서 각 집합 자체는 하나의 나무이고 뿌리의 자수(SubTree)라고 부른다.
두 갈래 나무(Binary Tree)는 n(n>=0)개의 결점의 유한한 집합으로 이 집합은 공집합(공두 갈래 나무라고 부른다)이거나 한 뿌리 결점과 두 그루가 서로 교차하지 않는 것을 각각 뿌리 결점이라고 부른다
왼쪽 나무와 오른쪽 나무의 두 갈래 나무로 이루어져 있다.
/* */
typedef struct BiTNode /* */
{
TElemType data; /* */
struct BiTNode *lchild, *rchild; /* */
} BiTNode, *BiTree;
두 갈래 나무의 스트리밍(traversing binary tree)은 뿌리 결점에서 출발하여 어떤 순서에 따라 두 갈래 나무의 모든 결점을 순서대로 방문하여 매 결점이 한 번 방문하고 한 번만 방문하는 것을 말한다.
두 갈래 나무를 옮겨다니는 방법은 다음과 같다.
1. 앞 순서 두루
/* */
void PreOrderTraverse(BiTree T)
{
if ( T==NULL )
return;
printf("%c",T->data); /* , */
PreOrderTraverse(T->lchild); /* */
PreOrderTraverse(T->rchild); /* */
}
2. 중간 순서 반복
/* */
void InOrderTraverse(BiTree T)
{
if ( T==NULL )
return;
InOrderTraverse(T->lchild); /* */
printf("%c",T->data); /* , */
InOrderTraverse(T->rchild); /* */
}
3. 후순 두루
/* */
void PostOrderTraverse(BiTree T)
{
if ( T==NULL )
return;
PostOrderTraverse(T->lchild); /* */
PostOrderTraverse(T->rchild); /* */
printf("%c",T->data); /* , */
}
4. 차례차례
층차순력서에 알고리즘이 첨부되어 있지 않으며 정리 결과는 다음과 같다.
층차 스트리밍 알고리즘에서 대기열(FIFO) 방식으로 이루어졌는데 대기열의 실현에 대해서는 자세히 말하지 않겠습니다.
/* */
void LayerOrderTraverse(BiTree T)
{
if ( T==NULL )
return;
BiTree *x;
Queue Q; /* Q */
InitQueue(&Q); /* Q */
EnQueue(&Q,T); /* */
while(! QueueEmpty(Q)) /* */
{
DeQueue(&Q, x); /* , x */
printf("%c",(*x)->data); /* , */
if ((*x)->lchild)
EnQueue(&Q,(*x)->lchild); /* , */
if ((*x)->rchild)
EnQueue(&Q,(*x)->rchild); /* , */
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.