《대화데이터구조》 독서노트(二)
트리(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에 따라 라이센스가 부여됩니다.