【数据结构】以孩子兄弟链表作存储结构,创建一棵树。并输出其先根、后根遍历序列;统计树中叶子结点的个数和深度

#include <iostream>
#define MAXSIZE 100
using namespace std;
typedef char ElemType;
typedef struct CSNode{
	ElemType data;
	struct CSNode *firstchild,*nextsibling;
}CSNode,*CSTree;
void CreateTree(CSTree &T)
{   char ch; 
	cin>>ch;
	if(ch=='#')
	  T=NULL;
	else
	{
		T=new CSNode;
		T->data=ch;
		CreateTree(T->firstchild);
		CreateTree(T->nextsibling);
	}
}
int n=0;
void CountLeaf(CSTree T)
{
	if(T)
	{
		if(!T->firstchild)
		  n++;
		  CountLeaf(T->firstchild);
		  CountLeaf(T->nextsibling);
	}
}
int Depth(CSTree T)
{   int d,dc,ds;
	if(!T)
	  d=0;
	else
	{
		dc=Depth(T->firstchild);
		ds=Depth(T->nextsibling);
		d=dc+1>+ds?dc+1:ds;
	 } 
	return d; 
}
void InOrderTraverse1(CSTree T) { 
	//先序遍历
	if(T) {
		cout<<T->data;
		InOrderTraverse1(T->firstchild);
		InOrderTraverse1(T->nextsibling);
	}
}
void InOrderTraverse2(CSTree T) {
	//中序遍历
	if(T) {
		InOrderTraverse2(T->firstchild);
		cout<<T->data;
		InOrderTraverse2(T->nextsibling);
	}
}
int main()
{
	CSTree s;
	int a;
	cout<<"请输入二叉树(孩子-兄弟)的元素!\n";
	CreateTree(s);
	cout<<"树的先根遍历输出为:\n";	
	InOrderTraverse1(s);
	cout<<"\n树的后根遍历输出为:\n";	
	InOrderTraverse2(s);
	CountLeaf(s);
	a=Depth(s);
	cout<<"\n树的深度为:"<<a;
	cout<<"树的叶子结点个数为:"<<n;
	
}

  • 14
    点赞
  • 76
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、实验目的: 理解二叉树特别是完全二叉树的性质,掌握二叉树存储结构(二叉链表);熟练掌握二叉树的常用操算法(初始化、插入结点、删除结点、遍历等);初步掌握二叉树的应用。 二、实验内容: 要求采用二叉链表存储结构,完成二叉树的建立,前序、中序和后序遍历的操,求所有叶子及结点总数的操等。 具体要求如下: ①给出基于二叉链表二叉树类的定义; ②给出二叉树初始化(构造函数)的实现; ③给出二叉树三种遍历算法的递归实现; ④二叉树先序遍历的非递归算法实现; ⑤利用二叉树的遍历算法求二叉树的结点数、二叉树的叶结点数、二叉树的高度; ⑥二叉树的撤销删除 三、实验步骤: 1、需求分析: 本演示程序用JAVA编写,完成树的生成,任意位置的插入、删除,以及遍历二叉树中的结点,查找和修改树中元素的值。 ① 输入的形式和输入值的范围:插入元素时需要输入插入的位置和元素的值;删除元素时输入删除元素的位置;遍历时采用三种遍历方法中的一种遍历方法;修改操时需要输入的元素的值;查找操时,需要找到要查找元素的位置。在所有输入中,元素的值都是整数。 ② 输出的形式:在所有四种操中都显示操是否正确以及操树中的内容。其中删除操后显示删除的元素的值,遍历二叉树中的元素,查找操、修改操后显示修改的值。 ③ 程序所能达到的功能:完成树的生成(通过插入操)、插入、删除、遍历、查找、修改操。 ④ 测试数据: A. 树中已有以50,25,75,12,37,43,30,33,87,93,97为关键字的结点 B. 插入操中依次输入10,20,30,40,50,60,70,80,90,100十个数 C. 删除操中输入10删除值为10的元素 D. 查找操中输入20,30,40,50返回这个元素在树中的位置 2.概要设计: 1)为了实现上述程序功能,需要定义树的抽象数据类型: public int iData; public double dData; public Node leftChild; public Node rightChild; private Node root;int value; private Node getSuccessor; 基本操:{ Tree () 操结果:构造一个空的二叉树 insert () 初始条件:是否存在一个空二叉树结果:往二叉树中插入数值 delete () 初始条件:存在一非空的二叉树条件:将二叉树中的元素删除 displayTree () 初始条件:存在一非空的树 操条件:显示非空树中的所有元素的值 getString () 初始条件:存在一非空的二叉树结果:返回整个字符串的数值 getChar () 初始条件:存在一非空的二叉树结果:返回字符型的数值 getInt () 初始条件:存在一非空的二叉树结果:返回整型的数值 find () 初始条件:存在一非空二叉树结果:从二叉树中查找某一元素 traverse () 初始条件:存在一非空的二叉树结果:对二叉树中的元素进行遍历 preorder () 初始条件:存在一非空的二叉树结果:对二叉树中的元素进行先根遍历 inOrder () 初始条件:存在一非空的二叉树结果:对二叉树中的元素进行中根遍历 postOrder () 初始条件:存在一非空的二叉树结果:对二叉树中的元素进行后根遍历 DisplayNode () 初始条件:存在一非空的二叉树结果:显示出二叉树中的整形数值和双精度浮点型数值 public static void main 操结果:调用主函数

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值