前序遍历

 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种遍历及其应用的更多相关文章

  1. HDU 1710 二叉树三种遍历

    Binary Tree Traversals Problem Description A binary tree is a finite set of vertices that is either ...

  2. 二叉树3种递归和非递归遍历(Java)

    import java.util.Stack; //二叉树3种递归和非递归遍历(Java) public class Traverse { /******************一二进制树的定义*** ...

  3. Python实现二叉树的四种遍历

    对于一个没学过数据结构这门课程的编程菜鸟来说,自己能理解数据结构中的相关概念,但是自己动手通过Python,C++来实现它们却总感觉有些吃力.递归,指针,类这些知识点感觉自己应用的不够灵活,这是自己以 ...

  4. 《数据结构与算法(C语言版)》严蔚敏 | 第五章 建立二叉树,并完成三/四种遍历算法

    PS:所有的代码示例使用的都是这个图 2019-10-29 利用p126的算法5.3建立二叉树,并完成三种遍历算法 中序 后序 先序 #include<iostream> #include ...

  5. 二叉树总结—建树和4种遍历方式(递归&&非递归)

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/27967155 今天总结一下二叉树.要考离散了 ...

  6. UVA - 548 根据中序遍历和后序遍历建二叉树(关于三种遍历二叉树)

    题意: 同时给两个序列,分别是二叉树的中序遍历和后序遍历,求出根节点到叶子结点路径上的权值最小和 的那个 叶子节点的值,若有多个最小权值,则输出最小叶子结点的和. 想法: 一开始想着建树,但是没有这样 ...

  7. 基于Java的二叉树的三种遍历方式的递归与非递归实现

    二叉树的遍历方式包括前序遍历.中序遍历和后序遍历,其实现方式包括递归实现和非递归实现. 前序遍历:根节点 | 左子树 | 右子树 中序遍历:左子树 | 根节点 | 右子树 后序遍历:左子树 | 右子树 ...

  8. PTA 二叉树的三种遍历(先序、中序和后序)

    6-5 二叉树的三种遍历(先序.中序和后序) (6 分)   本题要求实现给定的二叉树的三种遍历. 函数接口定义: void Preorder(BiTree T); void Inorder(BiTr ...

  9. java实现二叉树的Node节点定义手撕8种遍历(一遍过)

    java实现二叉树的Node节点定义手撕8种遍历(一遍过) 用java的思想和程序从最基本的怎么将一个int型的数组变成Node树状结构说起,再到递归前序遍历,递归中序遍历,递归后序遍历,非递归前序遍 ...

随机推荐

  1. MiniUI学习笔记1-新手必读

    1.mini的全局方法 2.Ajax jQuery 拥有完整的 Ajax 兼容套件.其中的函数和方法允许我们在不刷新浏览器的情况下从服务器加载数据. 详细jQuery Ajax教程,可参考这里. 3. ...

  2. 树——binary-tree-maximum-path-sum(二叉树最大路径和)

    问题: Given a binary tree, find the maximum path sum. The path may start and end at any node in the tr ...

  3. less:运算

    less中的运算 -任何数字.颜色或者变量都可以参加运算,运算应该被包裹在括号中. -例如:+-*. @width: 30px; .box { width: (20 + 5) * @width; } ...

  4. 理解Promise (1)

    new Promise 需要传递一个执行器 (函数) 函数有两个参数 resolve reject promise 承诺 默认的状态是pengding 调用 resolve 表示成功 reject 表 ...

  5. bzoj2085 [Poi2010]Hamsters 矩阵快速幂+字符串hash

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=2085 题解 考虑暴力 DP 的做法.令 \(dp[i][j]\) 表示以 \(j\) 为开头的 ...

  6. vue @import css

    @import '~@/assets/scss/helpers/_mixin'; 原理:CSS loader 会把把非根路径的url解释为相对路径, 加~前缀才会解释成模块路径.

  7. django之创建子应用

    一:子应用 Django的视图编写是放在子应用中的.类似于flask中的视图. 二:创建子应用 例如:在刚才的dj_study项目中,创建一个名字为user的子应用(目录):注意是第一级的dj_stu ...

  8. FreeRTOS之taskYIELD()

    摘自:http://www.mcuchina.com/article/2007/1227/article_59.html 1.taskYIELD()   比如我创建了8个优先级一样的task,并且没有 ...

  9. nginx主配置文件学习,以及nginx的反向代理和负载均衡

    1.nginx.conf主配置文件学习 worker_processes : 表示nginx的进程数,根据CPU的核数来定义,起到优化的作用.通过cat /proc/cpuinfo来查看核数 even ...

  10. rest认证组件,权限组件,频率组件,url注册器,响应器组件,分页器组件

    1.认证组件 1.1 认证组件利用token来实现认证 1.2 token认证的大概流程 用户登录===>获取用户名和密码===>查询用户表 如果用户存在,生成token,否则返回错误信息 ...