C++树之遍历二叉树实例详解

在讲遍历之前,我们要先创建一个树:

#include <iostream>
using namespace std;
typedef struct node;
typedef node *tree;

struct node{
 int data;    // 结点数值
 tree left,right;  // 左子树和右子树
};
tree bt;

遍历二叉树有三种方式:

先序遍历

先序遍历的操作如下:

  • 访问根结点
  • 先序遍历左子树(递归)
  • 先序遍历右子树(递归)

二叉树bt的先序遍历结果:12347536

代码如下:

void preorder(tree bt){
 if (bt){    // 判断不为空二叉树
  cout << bt->data;
  preorder(bt->left); // 递归遍历左子树
  preorder(bt->right); // 递归遍历右子树
 }
}

中序遍历

中序遍历的操作如下:

  • 中序遍历左子树(递归)
  • 访问根结点
  • 中序遍历右子树(递归)

二叉树bt的中序遍历结果:7425136

代码如下:

void inorder(tree bt){
 if (bt){    // 判断不为空二叉树
  inorder(bt->left); // 递归遍历左子树
  cout << bt->data;
  inorder(bt->right); // 递归遍历右子树
 }
}

后序遍历

后序遍历的操作如下:

  • 后序遍历左子树(递归)
  • 后序遍历右子树(递归)
  • 访问根结点

二叉树bt的后序遍历的结果:7452631

代码如下:

void postorder(tree bt){
  if (bt){        // 判断不为空二叉树
    postorder(bt->left);  // 递归遍历左子树
    postorder(bt->right); // 递归遍历右子树
    cout << bt->data;
  }
}

小结:我们使用递归的方式遍历了二叉树,大家仔细观察可以发现,先序遍历就是先访问根结点,再递归,中序遍历是把访问根结点放中间,后续遍历是最后访问。

总代码:

#include <iostream>
using namespace std;
typedef struct node;
typedef node *tree;

struct node{
  int data;        // 结点数值
  tree left,right;    // 左子树和右子树
};
tree bt;

void preorder(tree bt){
  if (bt){        // 判断不为空二叉树
    cout << bt->data;
    preorder(bt->left);  // 递归遍历左子树
    preorder(bt->right); // 递归遍历右子树
  }
}
void inorder(tree bt){
  if (bt){        // 判断不为空二叉树
    inorder(bt->left);  // 递归遍历左子树
    cout << bt->data;
    inorder(bt->right); // 递归遍历右子树
  }
}
void postorder(tree bt){
  if (bt){        // 判断不为空二叉树
    postorder(bt->left);  // 递归遍历左子树
    postorder(bt->right); // 递归遍历右子树
    cout << bt->data;
  }
}

补充知识:

表达式:a+b*c

表达式二叉树:

前缀表达式(波兰式):+a*bc

中缀表达式:a+b*c/d

后缀表达式(逆波兰式):abc*+

怎么将中缀表达式转换为前缀表达式或后缀表达式呢?只需像前序遍历和后序遍历一样遍历表达二叉树即可。

总结

到此这篇关于C++树之遍历二叉树的文章就介绍到这了,更多相关C++遍历二叉树内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C++实现二叉树非递归遍历方法实例总结

    一般来说,二叉树的遍历是C++程序员在面试中经常考察的,其实前中后三种顺序的遍历都大同小异,自己模拟两个栈用笔画画是不难写出代码的.现举一个非递归遍历的方法如下,供大家参考. 具体代码如下: class Solution { public: vector<int> preorderTraversal(TreeNode *root) { vector<int> out; stack<TreeNode*> s; s.push(root); while(!s.empty()

  • 二叉树遍历 非递归 C++实现代码

    二叉树的非递归遍历 二叉树是一种非常重要的数据结构,很多其它数据结构都是基于二叉树的基础演变而来的.对于二叉树,有前序.中序以及后序三种遍历方法.因为树的定义本身就是递归定义,因此采用递归的方法去实现树的三种遍历不仅容易理解而且代码很简洁.而对于树的遍历若采用非递归的方法,就要采用栈去模拟实现.在三种遍历中,前序和中序遍历的非递归算法都很容易实现,非递归后序遍历实现起来相对来说要难一点. 一.前序遍历 前序遍历按照"根结点-左孩子-右孩子"的顺序进行访问. 1.递归实现 复制代码 代码

  • 探讨:C++实现链式二叉树(用非递归方式先序,中序,后序遍历二叉树)

    如有不足之处,还望指正! 复制代码 代码如下: // BinaryTree.cpp : 定义控制台应用程序的入口点.//C++实现链式二叉树,采用非递归的方式先序,中序,后序遍历二叉树#include "stdafx.h"#include<iostream>#include<string>#include <stack>using namespace std;template<class T>struct BiNode{ T data; 

  • C++基于先序、中序遍历结果重建二叉树的方法

    本文实例讲述了C++基于先序.中序遍历结果重建二叉树的方法.分享给大家供大家参考,具体如下: 题目: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回. 实现代码: #include <iostream> #include <vector> #include <stack> using

  • C++ 数据结构二叉树(前序/中序/后序递归、非递归遍历)

    C++ 数据结构二叉树(前序/中序/后序递归.非递归遍历) 二叉树的性质: 二叉树是一棵特殊的树,二叉树每个节点最多有两个孩子结点,分别称为左孩子和右孩子. 例: 实例代码: #include <iostream> #include <Windows.h> #include <stack> using namespace std; template <class T> struct BinaryTreeNode { int _data; BinaryTree

  • c++二叉树的几种遍历算法

    1. 前序/中序/后序遍历(递归实现) 复制代码 代码如下: // 前序遍历void BT_PreOrder(BiTreePtr pNode){ if (!pNode)  return;    visit(pNode);   BT_PreOrder(pNode->left); BT_PreOrder(pNode->right);   }// 中序遍历void BT_PreOrder(BiTreePtr pNode){  if (!pNode)  return;     BT_PreOrder(

  • C++ 遍历二叉树实例详解

    C++ 遍历二叉树实例详解 2叉数又叫红黑树,关于2叉数的遍历问题,有很多,一般有三种常用遍历方法: (1)前序遍历(2)中序遍历(3)后续遍历 以下是经典示例: #include "stdafx.h" #include<stdio.h> #include<malloc.h> #include <math.h > #define MaxSize 20 typedef struct BiTNode { int data; struct BiTNode

  • C++实现二叉树遍历序列的求解方法

    本文详细讲述了C++实现二叉树遍历序列的求解方法,对于数据结构与算法的学习有着很好的参考借鉴价值.具体分析如下: 一.由遍历序列构造二叉树 如上图所示为一个二叉树,可知它的遍历序列分别为: 先序遍历:ABDECFG 中序遍历:DBEAFCG 后序遍历:DEBFGCA 我们需要知道的是,由二叉树的先序序列和中序序列可以唯一地确定一棵二叉树:由二叉树的后序序列和中序序列也可以唯一地确定一棵二叉树:但是如果只知道先序序列和后序序列,则无法唯一确定一棵二叉树. 二.已知二叉树的先序序列和中序序列,求后序

  • 一波二叉树遍历问题的C++解答实例分享

    题目一: 输入一颗二元树,从上往下按层打印树的每个节点,同一层按照从左往右的顺序打印. 输入样例: 8 / / 6 10 / / / / 5 7 9 11 输出样例: 复制代码 代码如下: 8 6 10 5 7 9 11 思路分析: 把一颗二叉树抽象成三个节点:根节点.左节点.右节点. 先序遍历即可得到按行输出的效果. 对于左子树只要保存其根节点,既保存了整个左子树.(右子树一样) 对于根节点之外的两个子树来说说,始终是先访问左子树的根节点,再访问右子树的根节点. 因此可以使用队列存储. 代码实

  • C++非递归队列实现二叉树的广度优先遍历

    本文实例讲述了C++非递归队列实现二叉树的广度优先遍历.分享给大家供大家参考.具体如下: 广度优先非递归二叉树遍历(或者说层次遍历): void widthFirstTraverse(TNode* root) { queue<TNode*> q; // 队列 q.enqueue(root); TNode* p; while(q.hasElement()) { p = q.dequeue(); // 队首元素出队列 visit(p); // 访问p结点 if(p->left) q.enqu

随机推荐