您的位置:首页 > 其它

二叉排序树BST 静态实现

2018-03-10 12:41 211 查看
5
1 6 5 9 8

/*
二叉排序树的建立
*/
#include<stdio.h>
#include<string.h>
struct Node{
Node* lchild;
Node* rchild;
int data;
}Tree[101];
int loc;
Node *creat(){
Tree[loc].lchild=Tree[loc].rchild=NULL;
return &Tree[loc++];
}

void PreOrder(Node *T){
printf("%d ",T->data);
if(T->lchild)	PreOrder(T->lchild);
if(T->rchild)	PreOrder(T->rchild);
}
void InOrder(Node *T){
if(T->lchild)	InOrder(T->lchild);
printf("%d ",T->data);
if(T->rchild)	InOrder(T->rchild);
}

void PostOrder(Node *T){
if(T->lchild)	PostOrder(T->lchild);
if(T->rchild)	PostOrder(T->rchild);
printf("%d ",T->data);
}
//插入方法,按大小顺序插入左右分支,走到底时建立新节点
Node *Insert(Node *T,int x){//返回创建的节点
if(T==NULL){//走到底了
T=creat();
T->data=x;
return T;//用作返回的时候做孩子
}
else if(x<T->data)	T->lchild=Insert(T->lchild,x);
else if(x>T->data)	T->rchild=Insert(T->rchild,x);
return T;//最后一次返回的是传进来的跟节点
}

Node* MyInsert(Node *T,int x){//插入后要返回根指针
Node* temp=T;
while(T!=NULL){
if(x<T->data)	T=T->lchild;
else if(x>T->data)	T=T->rchild;
else return temp;//相等时直接结束
}
T=creat();
T->data=x;
if(temp==NULL)	return T;
else return temp;
}

int main(){
int n,x;
while(scanf("%d",&n)!=EOF){
Node *T=NULL;
for(int i=0;i<n;i++){
scanf("%d",&x);
T=MyInsert(T,x);//保证对树修改的同时保留根节点指针
}
PreOrder(T);
printf("\n");
InOrder(T);
printf("\n");
PostOrder(T);
printf("\n");

}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: