tree.cpp

来自「C++编程实例100篇电子书」· C++ 代码 · 共 98 行

CPP
98
字号
#include "Tree.h"

void TREE::BUILD_TREE(NODE *&Root,int Data)
{
	NODE *TEMP;
	NODE *BACKTEMP;
	if(Root == 0)
	{
		Root=new NODE;
		Root->LEFT=Root->RIGHT=0;
		Root->DATA=Data;
	}
	else
	{
			TEMP=Root;
			while(TEMP!=0)
			{
					BACKTEMP=TEMP;
					if(Data<(TEMP->DATA)) TEMP=TEMP->LEFT;
					else TEMP=TEMP->RIGHT;
			}
			if(Data<(BACKTEMP->DATA))
			{
				NODE *NEWNODE=new NODE;
				NEWNODE->LEFT=NEWNODE->RIGHT=0;
				NEWNODE->DATA=Data;
				BACKTEMP->LEFT=NEWNODE;

			}
			else
			{
				NODE *NEWNODE=new NODE;
				NEWNODE->LEFT=NEWNODE->RIGHT=0;
				NEWNODE->DATA=Data;
				BACKTEMP->RIGHT=NEWNODE;
			}
	}
}

void TREE::LR_PREORDER(NODE *Root)
{
	if(Root!=NULL)
	{
		printf("%d  ",Root->DATA);
		LR_PREORDER(Root->LEFT);
		LR_PREORDER(Root->RIGHT);
	}
}

void TREE::LR_INORDER(NODE *Root)
{
	if(Root!=NULL)
	{
		LR_INORDER(Root->LEFT);
		printf("%d  ",Root->DATA);
		LR_INORDER(Root->RIGHT);
	}
}

void TREE::LR_POSTORDER(NODE *Root)
{
	if(Root!=NULL)
	{
		LR_POSTORDER(Root->LEFT);
		LR_POSTORDER(Root->RIGHT);
		printf("%d  ",Root->DATA);
	}
}

void TREE::RL_PREORDER(NODE *Root)
{
	if(Root!=NULL)
	{
		printf("%d  ",Root->DATA);
		RL_PREORDER(Root->RIGHT);
		RL_PREORDER(Root->LEFT);
	}
}

void TREE::RL_INORDER(NODE *Root)
{
	if(Root!=NULL)
	{
		RL_INORDER(Root->RIGHT);
		printf("%d  ",Root->DATA);
		RL_INORDER(Root->LEFT);
	}
}

void TREE::RL_POSTORDER(NODE *Root)
{
	if(Root!=NULL)
	{
		RL_POSTORDER(Root->RIGHT);
		RL_POSTORDER(Root->LEFT);
		printf("%d  ",Root->DATA);
	}
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?