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;
}
二叉排序树BST 静态实现
最新推荐文章于 2022-02-24 17:45:24 发布