Code Up 9.4问题 A: 二叉排序树(二叉排序树的建立与遍历)

问题 A: 二叉排序树

 

题目描述

输入一系列整数,建立二叉排序数,并进行前序,中序,后序遍历。

输入

输入第一行包括一个整数n(1<=n<=100)。接下来的一行包括n个整数。

输出

可能有多组测试数据,对于每组数据,将题目所给数据建立一个二叉排序树,并对二叉排序树进行前序、中序和后序遍历。每种遍历结果输出一行。每行最后一个数据之后有一个空格。

样例输入

1
2 
2
8 15 
4
21 10 5 39 

样例输出

2 
2 
2 
8 15 
8 15 
15 8 
21 10 5 39 
5 10 21 39 
5 10 39 21 

利用输入数据建立二次排序树,并进行先序、中序、后序遍历。特别注意,此题可能有重复元素,若50%正确,则是没有去除重复元素。

参考代码:

# include<cstdio>
# include<vector>
using namespace std;
struct node{
	int data;
	node *lchild,*rchild;
}; 

void insert(node* &root,int data) //一定别忘了root前的&! 
{
	if(root==NULL)
	{
		root=new node;
		root->data=data;
		root->lchild=root->rchild=NULL;
		return;
	}
	if(root->data==data) //去除重复的元素。重要!
		return ; 
	if(data<root->data)
		insert(root->lchild,data);
	else
		insert(root->rchild,data);
}
void preorder(node *root,vector<int> &vi) //先序遍历,结果存于pre中 
{
	if(root==NULL)
		return;
	vi.push_back(root->data);
	preorder(root->lchild,vi);
	preorder(root->rchild,vi);
}
void inorder(node* root,vector<int> &vi)  //中序遍历,结果存于in中 
{
	if(root==NULL)
		return;
	inorder(root->lchild,vi);
	vi.push_back(root->data);
	inorder(root->rchild,vi);
}
void postorder(node* root,vector<int> &vi) //后序遍历,结果存于post 
{
	if(root==NULL)
		return;
	postorder(root->lchild,vi);
	postorder(root->rchild,vi);
	vi.push_back(root->data); 
}



int main()
{
	int n,data;
	while(scanf("%d",&n)!=EOF)
	{
		vector<int> pre,in,post;
		node*root=NULL;//定义头结点! 
		for(int i=0;i<n;++i)
		{
			scanf("%d",&data);
			insert(root,data);
		}
		preorder(root,pre);
		inorder(root,in);
		postorder(root,post);
		for(int i=0;i<pre.size();++i)
			printf("%d ",pre[i]);
		printf("\n");
		for(int i=0;i<in.size();++i)
			printf("%d ",in[i]);
		printf("\n");
		for(int i=0;i<post.size();++i)
			printf("%d ",post[i]);
		printf("\n");
	}
	return 0;
 } 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值