二叉树三种遍历方式及其实现

2024-06-24 11:38

本文主要是介绍二叉树三种遍历方式及其实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、基本概念

每个结点最多有两棵子树,左子树和右子树,次序不可以颠倒。

性质:

1、非空二叉树的第n层上至多有2^(n-1)个元素。

2、深度为h的二叉树至多有2^h-1个结点。

3、对任何一棵二叉树T,如果其终端结点数(即叶子结点数)为n0,度为2的结点数为n2,则n0 = n2 + 1。

满二叉树:所有终端都在同一层次,且非终端结点的度数为2。

在满二叉树中若其深度为h,则其所包含的结点数必为2^h-1。

完全二叉树:除了最大的层次即成为一颗满二叉树且层次最大那层所有的结点均向左靠齐,即集中在左面的位置上,不能有空位置。

对于完全二叉树,设一个结点为i则其父节点为i/2,2i为左子节点,2i+1为右子节点。

二、二叉树的遍历
遍历二叉树的所有结点且仅访问一次。按照根节点位置的不同分为前序遍历,中序遍历,后序遍历。


前序遍历:根节点->左子树->右子树(根节点在前面

中序遍历:左子树->根节点->右子树根节点在中间

后序遍历:左子树->右子树->根节点根节点在后边

例如:求下面树的三种遍历

 

前序遍历:abdefgc

中序遍历:debgfac

后序遍历:edgfbca

三、二叉树三种遍历方式的六种实现方法

#include <iostream>  
#include <string>  
#include <stack>  
#include <vector>  
using namespace std;  
struct Node  
{  int val;  Node * left;  Node * right;  Node(int x) :val(x), left(nullptr), right(nullptr){};  
};  void creatBiTree(Node * &root)  
{  int x;  cin >> x;  if (x == -1)  {  root = nullptr;  return;  }  root = new Node(x);  creatBiTree(root->left);  creatBiTree(root->right);  
}  
void visit(Node *T)  
{  if (T->val != -1)  cout << T->val << " ";  }  
/**递归方式遍历**/  
//先序递归遍历  
void preOrder(Node * root)  
{  if (root != nullptr)  {  visit(root);  preOrder(root->left);  preOrder(root->right);  }  
}  
//中序递归遍历  
void inOrder(Node * root)  
{  if (root != nullptr)  {  inOrder(root->left);  visit(root);  inOrder(root->right);  }  
}  
//后序递归遍历  
void postOrder(Node * root)  
{  if (root != nullptr)  {  postOrder(root->left);  postOrder(root->right);  visit(root);  }  
}  
/**非递归方式遍历**/  
//先序遍历  
void preOrderF(Node * root)  
{  if (root == nullptr)  return;  stack<Node *> s;  s.push(root);  Node *p = nullptr;  while (!s.empty())  {  p = s.top();  s.pop();  cout << p->val << " ";  if (p->right)  s.push(p->right);  if (p->left)  s.push(p->left);  }  
}  
//中序遍历  
void inOrderF(Node * root)  
{  if (root == nullptr)  return;  stack<Node *> s;  Node *p = root;  while (p||!s.empty())  {  if (p)  {  s.push(p);  p = p->left;  }  else   {  p = s.top();  s.pop();  cout << p->val << " ";  p = p->right;  }  }  }  
//后序遍历  
void postOrderF(Node * root)  
{  if (root == nullptr)  return;  stack<Node *> s;  vector<int> rs;  s.push(root);  Node *p = nullptr;  while (!s.empty())  {  p = s.top();  s.pop();  rs.insert(rs.begin(),p->val);  if (p->left)  s.push(p->left);  if (p->right)  s.push(p->right);  }  for (int i = 0; i < rs.size(); i++)  cout << rs[i] << " ";  
}  
int _tmain(int argc, _TCHAR* argv[])  
{  Node * root;  //二叉树的创建(根据先序创建)  creatBiTree(root);  //二叉树的递归遍历  preOrderF(root);  cout << endl;  inOrderF(root);  cout << endl;  postOrderF(root);  cout << endl;  return 0;  
}  


这篇关于二叉树三种遍历方式及其实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1090045

相关文章

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推