二叉树BinTree4种遍历及其应用
前序遍历
template<class T>
void BinTree<T>::PreOrder(BinTreeNode<T>*subTree){
//前序遍历以subTree为根的树
if(subTree!=NULL){
cout<<subTree->data<<endl;
PreOrder(subTree->leftChild);
PreOrder(subTree->rightChild);
}
}
中序遍历
template<class T>
void BinTree<T>::InOrder(BinTreeNode<T>*subTree){
//中序遍历以subTree为根的树
if(subTree!=NULL){//NULL是递归终止条件
InOrder(subTree->leftChild);//中序遍历左子树
cout<<subTree->data<<endl;//访问根结点
InOrder(subTree->rightChild);//中序遍历右子树
}
}
后序遍历
template<class T>
void BinTree<T>::PostOrder(BinTreeNode<T>*subTree){
//后序遍历以subtree为根的树
if(subTree!=NULL){
PostOrder(subTree->leftChild);
PostOrder(subTree->rightChild);
cout<<subTree->data<<endl;
}
}
已知中序排列,和先序排列,可以还原二叉树,并推出后序排列。
已知中序排列,和后序排列,可以还原二叉树,并推出先序排列。
但是已知先序排列和后序排列,可能无法唯一确定二叉树。
层次序遍历,需要用到队列
template<class T>
void BinTree<T>::LevelOrder(BinTreeNode<T>*subTree) {
//层次序遍历以subTree为根的二叉树
Queue<BinTreeNode<T>*>Q;//定义队列
BinTreeNode<T>*p=subTree;
Q.EnQueue(p);//根结点入队
while(!Q.IsEmpty()){//队列不空
Q.DeQueue(p);
cout<<p->data;
if(p->leftChild!=NULL) Q.EnQueue(p->leftChild);//左子入队
if(p->rightChild!=NULL) Q.EnQueue(p->rightChild);//右子入队
}
}
遍历看完后,接下来是遍历的应用以及遍历思想的应用
前序遍历的应用——复制构造函数与复制函数
template<class T>
BinTree<T>::BinTree(const BinTree<T>&s){
//复制构造函数
root=Copy(s.root);
}
template<class T>
BinTreeNode<T>* BinTree<T>::Copy(BinTreeNode<T>*orignode){
//返回一个指针,它给出一个以orignode为根的二叉树的副本
if(orignode==NULL) return NULL;
BinTreeNode<T>*temp=new BinTreeNode<T>;//创建根结点
temp->data=orignode->data;
temp->leftChild=Copy(orignode->leftChild);
temp->rightChild=Copy(orignode->rightChild);
return temp;
}
前序遍历的应用——判断两颗二叉树是否相等
template<class T>
bool equal(BinTreeNode<T>*a,BinTreeNode<T>*b){
//为BinTree类的友元函数
if(a==NULL&&b==NULL) return true;
if(a!=NULL&&b!=NULL&&a->data==b->data&&equal(a->leftChild,b->leftChild)&&equal(a->rightChild,b->rightChild)) return true;
else return false;
}
前序遍历的应用——利用前序遍历建立二叉树
约定以输入序列中不可能出现的值作为空结点的值以结束递归,此值在RefValue中,如#
template<class T>
void BinTree<T>::CreatBinTree(ifstream& in,BinTreeNode<T>*&subTree){
//以递归的方式建立二叉树
T item;
if(!in.eof()){//未读完,读入并建树
in>>item;
if(item!=RefValue){
subTree->data=item;
CreatBinTree(in,subTree->leftChild);//递归建立左子树
CreatBinTree(in,subTree->rightChild);//递归建立右子树
}
else subTree=NULL;
}
}
后序遍历的应用——计算结点的个数
template<class T>
int BinTree<T>::Size(BinTreeNode<T>*subTree) const{
//计算以subTree为根的二叉树的结点的个数
;//递归结束
+Size(subTree->leftChild)+Size(subTree->rightChild);
}
后序遍历的应用——计算树的高度
template<class T>
int BinTree<T>::Height(BinTreeNode<T>*subTree) const{
//计算以subTree为根的二叉树的高度
;
+max(Height(subTree->leftChild),Height(subTree->rightChild));
}
二叉树BinTree4种遍历及其应用的更多相关文章
- HDU 1710 二叉树三种遍历
Binary Tree Traversals Problem Description A binary tree is a finite set of vertices that is either ...
- 二叉树3种递归和非递归遍历(Java)
import java.util.Stack; //二叉树3种递归和非递归遍历(Java) public class Traverse { /******************一二进制树的定义*** ...
- Python实现二叉树的四种遍历
对于一个没学过数据结构这门课程的编程菜鸟来说,自己能理解数据结构中的相关概念,但是自己动手通过Python,C++来实现它们却总感觉有些吃力.递归,指针,类这些知识点感觉自己应用的不够灵活,这是自己以 ...
- 《数据结构与算法(C语言版)》严蔚敏 | 第五章 建立二叉树,并完成三/四种遍历算法
PS:所有的代码示例使用的都是这个图 2019-10-29 利用p126的算法5.3建立二叉树,并完成三种遍历算法 中序 后序 先序 #include<iostream> #include ...
- 二叉树总结—建树和4种遍历方式(递归&&非递归)
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/27967155 今天总结一下二叉树.要考离散了 ...
- UVA - 548 根据中序遍历和后序遍历建二叉树(关于三种遍历二叉树)
题意: 同时给两个序列,分别是二叉树的中序遍历和后序遍历,求出根节点到叶子结点路径上的权值最小和 的那个 叶子节点的值,若有多个最小权值,则输出最小叶子结点的和. 想法: 一开始想着建树,但是没有这样 ...
- 基于Java的二叉树的三种遍历方式的递归与非递归实现
二叉树的遍历方式包括前序遍历.中序遍历和后序遍历,其实现方式包括递归实现和非递归实现. 前序遍历:根节点 | 左子树 | 右子树 中序遍历:左子树 | 根节点 | 右子树 后序遍历:左子树 | 右子树 ...
- PTA 二叉树的三种遍历(先序、中序和后序)
6-5 二叉树的三种遍历(先序.中序和后序) (6 分) 本题要求实现给定的二叉树的三种遍历. 函数接口定义: void Preorder(BiTree T); void Inorder(BiTr ...
- java实现二叉树的Node节点定义手撕8种遍历(一遍过)
java实现二叉树的Node节点定义手撕8种遍历(一遍过) 用java的思想和程序从最基本的怎么将一个int型的数组变成Node树状结构说起,再到递归前序遍历,递归中序遍历,递归后序遍历,非递归前序遍 ...
随机推荐
- 在Eclipse-jee-neon中配置Hibernate(jbosstools)
以下是在eclipse上安装Hibernate的插件,hibernate在编程上坚持出现,故需要在eclipse上进行如下安装. 首先把安装Hibernate插件,常用到JBoss,访问http:// ...
- SwiftUI 里的 swift 闭包总结
创建 UI 时的闭包使用 在 SwiftUI 里闭包出现的频率特别高,这里我重新梳理了下闭包的定义. 关于闭包 闭包表达式语法的一般形式如下: {(parameters) -> return t ...
- 用C#实现获取文件夹大小的源代码
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Tex ...
- Sql Server中的标识列(自增长字段)
一.标识列的定义以及特点 SQL Server中的标识列又称标识符列,习惯上又叫自增列.该种列具有以下三种特点: 1.列的数据类型为不带小数的数值类型2.在进行插入(Insert)操作时,该列的值是由 ...
- 一、模型验证CoreWebApi 管道方式(非过滤器处理)
一.新建.Net Core的MVC项目添加WebApi控制器的方式 using System; using System.Collections.Generic; using System.Linq; ...
- 脚本_查看所有虚拟机磁盘以及 CPU 的使用量
#!bin/bash#作者:liusingbon#功能:查看所有虚拟机磁盘使用量以及 CPU 使用量信息read -p "按任意键进入查看页面.比如按下Enter键" keyvir ...
- Centos7搭建日志服务器rsyslog+loganalyzer
一.系统环境 Rsyslog Server OS:CentOS 7 Rsyslog Server IP:172.28.194.118 Rsyslog Version: rsyslog-7.4.7-12 ...
- Ubuntu16.04 启用root权限
装了Ubuntu 16.04之后想使用超级权限对系统进行操作 使用命令 su - 切换超级用户,提示输入密码,却怎么都不对,网上找的资料说是没有启用root权限,于是根据网上提供的方法启用root权限 ...
- java并发学习--第二章 spring boot实现线程的创建
除了之前介绍的创建线程方式外,spring boot为我们了提供一套完整的线程创建方式,其中包括了:线程.线程池.线程的监控. 一.使用spring boot提供的方法创建线程与线程池 1.首先在sp ...
- 前端每日实战:93# 视频演示如何用纯 CSS 创作一根闪电连接线
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/RBjdzZ 可交互视频 此视频是可 ...