遍历数据结构课程设计 二叉树的遍历 修订-可编辑

二叉树遍历  时间:2021-02-08  阅读:()

树型结构是信 息的一种 重要组织形式

树是最为常用 的数据结构它的实际应用非常广泛二叉

序遍历有中序和后序遍历序列可以唯一确定一棵二叉树。对于给几个数据的排序或在已知的几个数据中进行查找二叉树均能提供一种十分有效的方法比如在查找问题上任何借助于比较法查找长度为Ⅳ的一个序表的算法都可以表示成一株二叉树。反之任何二叉树都对应一个查找有序表的有效方法根据树的数学理论对于算法分析的某些最有启发性的应用是与给出用于计算各种类型中不同树的数目的公式有关的。

本文对二叉树以及二叉树的各种功能做介绍以及写出一些基本的程序让我们对二叉树的理解有更好的效果。

关键词二叉树的遍历左子树右子树递归

目录

1 .问题概述

1 . 1问题描述

创建二叉树并遍历基本要求

该程序集成了如下功能

 1 二叉树的建立

2递归和非递归先序中序和后序遍历二叉树

3按层次遍历二叉树

4交换二叉树的左右子树

5输出叶子结点

6递归和非递归计算叶子结点的数目

1 . 2需求分析

分先序遍历中序遍历和后序遍历三种情况考虑。

1 .先序遍历当二叉树非空时按以下顺序遍历否则结束操作① 访问根结点

② 按先序遍历规则遍历左子树

③ 按先序遍历规则遍历右子树

2. 中序遍历当二叉树非空时按以下顺序遍历否则结束操作① 按中序遍历规则遍历左子树

② 访问根结点

③ 按中序遍历规3遍历右子树。

3.后序遍历当二叉树非空时按以下顺序遍历否则结束操作① 按后序遍历规则遍历左子树

② 按后序遍历规则遍历右子树

1 . 3设计内容和要求

对任意给定的二叉树顶点数自定建立它的二叉链表存贮结构并利用栈的五种基本运算清空堆栈、压栈、弹出、取栈顶元素、判栈空实现二叉树的先序、 中序、后序三种周游输出三种周游的结果。

1 .4流程图及结构图

开始i=0

图1b

c

a

图1 .2二叉链表存储结构模拟图

2.概要设计

2. 1数据结构设计

1  二叉树结点数据类型定义为template<typename T>struct BiNode

{

BiNode<T>*rchi ld,*lchi ld;//指向左孩子的指针

T data;//结点数据信息};

2  二叉树数据类型定义为template<typename T>class BiTree{template<typename T>friend ostream&operator<<(ostream&os,BiTree<T>&bt);publ ic:B i Tree();//无参构造函数

BiTree(int m){};//有参空构造函数

BiTree(T ary[], int num,T none);//有参构造函数

B i Tree();//析构函数void preorder();//递归前序遍历void inorder();//递归中序遍历void postorder();//递归后续遍历void levelorder();//层序遍历int count();//计算二叉树的结点数void display(ostream&os);//打印二叉树有层次

void creat();//创建二叉树protected: //以下函数供上面函数调用//对应相同功能

Voidcreat(BiNode<T>*&root);//创建void release(BiNode<T>*&root);//删除

BiNode<T>*Bui ld(Tary[], intnum,T none, int idx);//用数组创建二叉树void PreOrder(BiNode<T>* root);//前序遍历void PostOrder(BiNode<T>* root);//后续遍历void LevelNum(BiNode<T>* root);//层序遍历void preorder(Bi Node<T>* root);//递归前序遍历void inorder(BiNode<T>* root);//递归中序遍历void postorder(BiNode<T>* root);//递归后续遍历void levelorder(BiNode<T>*root);//层序遍历int count(BiNode<T>* root);//计算结点数void display(ostream&os,BiNode<T>* root, int dep);//打印static bool leastCommanAncestor(BiNode<T>*root,T va,T vb,BiNode<T>private:BiNode<T>*rootptr;

};

2. 2源程序代码

#include <iostream>usi ng namespace std;

*******************************************************************

******************

T data;

BTNode<T> * Lch i l d,*Rch i l d;

BTNode(T nodeVal ue = T() ,BTNode<T>* l ef tNode = NULL,BTNode<T>*r i ghtNode =NULL )

:data(nodeValue) ,Lchi ld( l ef tNode) ,Rchi ld( r ightNode){ } //可选择参数的默认构造函数

} ;

*******************************************************************

*******************

//二叉树的建立template <class T>voi d createB i nTree(BTNode<T> * &root )

{

BTNode<T>* p = root ;

BTNode<T>* k;

T nodeValue ;ci n>>nodeVal ue;i f (nodeValue==-1 )

{r o o t=NULL;

}else

{root=new BTNode<T>() ;root->data = nodeVal ue;createBinTree( root->Lchi ld) ;createBinTree( root->Rchi ld) ;

}

//二叉树的先序遍历template <class T>void preOrder( BTNode<T> * &p)

{i f (p)

{cout<<p->data<<" " ;preOrder(p->Lchi ld) ;preOrder(p->Rchi ld) ;

}

}

*******************************************************************

*******************

//二叉树的中序遍历template <class T>void i nOrder(BTNode<T> * &p)

{i f (p)

{i nOrder(p->Lchi ld) ;cout<<p->data<<" " ;i nOrder(p->Rchi ld) ;

}

}

*******************************************************************

*******************

//二叉树的后序遍历

爱用云互联租用服务器租美国、日本、美国、日本、购买2天内不满意可以退换,IP可免费更换!

爱用云互联怎么样?爱用云是一家成立于2018年的老牌商家旗下的服务器销售品牌,是正规持证IDC/ISP/IRCS商家,主要销售国内、中国香港、国外服务器产品,线路有腾讯云国外线路、自营香港CN2线路等,都是中国大陆直连线路,非常适合免备案建站业务需求和各种负载较高的项目,同时国内服务器也有多个BGP以及高防节点。专注为个人开发者用户,中小型,大型企业用户提供一站式核心网络云端服务部署,促使用户云端...

Virtono:圣何塞VPS七五折月付2.2欧元起,免费双倍内存

Virtono是一家成立于2014年的国外VPS主机商,提供VPS和服务器租用等产品,商家支持PayPal、信用卡、支付宝等国内外付款方式,可选数据中心共7个:罗马尼亚2个,美国3个(圣何塞、达拉斯、迈阿密),英国和德国各1个。目前,商家针对美国圣何塞机房VPS提供75折优惠码,同时,下单后在LET回复订单号还能获得双倍内存的升级。下面以圣何塞为例,分享几款VPS主机配置信息。Cloud VPSC...

华纳云,3折低至优惠云服务器,独立服务器/高防御服务器低至6折,免备案香港云服务器CN2 GIA三网直连线路月付18元起,10Mbps带宽不限流量

近日华纳云发布了最新的618返场优惠活动,主要针对旗下的免备案香港云服务器、香港独立服务器、香港高防御服务器等产品,月付6折优惠起,高防御服务器可提供20G DDOS防御,采用E5处理器V4CPU性能,10Mbps独享CN2 GIA高速优质带宽,有需要免备案香港服务器、香港云服务器、香港独立服务器、香港高防御服务器、香港物理服务器的朋友可以尝试一下。华纳云好不好?华纳云怎么样?华纳云服务器怎么样?...

二叉树遍历为你推荐
站长故事部队里什么是站长?最低是什么级别?都有哪些级别啊?在线漏洞检测网站检测工具,谁有?百度抢票浏览器猎豹浏览器,360抢票,百度卫士抢票哪个抢票工具好?9flash怎么使用ePSXe啊?申请证书求高手教下怎么申请证书迅雷云点播账号求迅雷云播账号网站优化方案网站优化方案如何写?怎么上传音乐怎样可以上传本地音乐到网上?如何修改ie主页IE主页怎样修改?首页无法修改主页不能修改怎么办
免费com域名申请 域名备案只选云聚达 gateone 免费网站监控 华为4核 个人域名 165邮箱 idc资讯 129邮箱 idc查询 江苏双线服务器 百度云加速 下载速度测试 免费的域名 ledlamp 江苏徐州移动 攻击服务器 乐视会员免费领取 湖南铁通 中美互联网论坛 更多