二叉树的创建 先序 中序 后续 递归和非递归遍历

2024-06-12 02:32

本文主要是介绍二叉树的创建 先序 中序 后续 递归和非递归遍历,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#include <iostream>
#include <stack>using namespace std;int index = 0;//标记着数组的下标
typedef struct BiTree
{int data;BiTree *lchild;BiTree *rchild;
}*Tree;//创建二叉树,需要使用结构体指针 这样树的结构出了函数 还会保存状态
void createBT(Tree &root,int data[])
{int value = data[index++];if(value == -1){root = NULL;}else{root = new BiTree;root->data = value;createBT(root->lchild,data);createBT(root->rchild,data);}
}
//二叉树的后序遍历 非递归
/**
根据后序遍历的形式 左->右->根,若访问的当前节点的左右孩子为空 就输出其值,要是
访问的当前节点的前驱存在 存在着左右孩子 即访问左右孩子节点 输出值 并将当前节点
至为前驱节点 以便下次访问 若不满足这俩种情况,按照栈的顺序 依次压入右孩子 、左孩子。
*/
void PostOrder(Tree& root)
{BiTree* cur;BiTree* pre = NULL;stack<BiTree*> s;if(root == NULL)return;s.push(root);while(!s.empty()){cur = s.top();if((cur->lchild == NULL && cur->rchild == NULL) ||(pre != NULL &&(pre ==cur->lchild || pre == cur->rchild))){cout << cur->data << " ";s.pop();pre = cur;}else{if(cur->rchild!=NULL)s.push(cur->rchild);if(cur->lchild!=NULL)s.push(cur->lchild);}}cout << endl;
}//后序遍历递归的形式
void visit(Tree&);
void PostOrder_Digui(Tree &root)
{if(root == NULL)return;PostOrder_Digui(root->lchild);PostOrder_Digui(root->rchild);visit(root);
}void visit(Tree &root)
{cout << root->data <<" ";
}//二叉树的先序遍历 递归形式
void PreOrder(Tree& root)
{if(root == NULL)return;visit(root);PreOrder(root->lchild);PreOrder(root->rchild);
}
//先序非递归的形式:
void PreOrder_Fdigui(Tree &root)
{stack<BiTree*> s;if(root == NULL)return;while(root || !s.empty()){while(root){s.push(root);cout << root->data << " ";root = root->lchild;}root = s.top();root = root->rchild;s.pop();}
}
//二叉树的中序遍历 递归的形式
void Inorder_Digui(Tree& root)
{if(root == NULL)return;Inorder_Digui(root->lchild);visit(root);Inorder_Digui(root->rchild);
}
//二叉树中序遍历非递归
void Inorder(Tree &root)
{stack<BiTree*> s;if(root == NULL)return;while(root || !s.empty()){while(root){s.push(root);root = root->lchild;}root = s.top();cout << root->data << " ";root = root->rchild;s.pop();}
}int main()
{int data[] = {8,6,4,-1,-1,7,-1,-1,10,9,-1,-1,11,-1,-1};Tree tree;createBT(tree,data);cout<<"输出树的遍历形式:"<<endl;PostOrder(tree);cout<<"后序递归形式:" << endl;PostOrder_Digui(tree);cout << endl;cout<<"先序遍历递归的形式:"<<endl;PreOrder(tree);cout << endl;cout << "先序非递归的形式:" << endl;PreOrder_Fdigui(tree);out << endl;cout << "中序遍历递归:" << endl;Inorder_Digui(tree);cout << endl;cout << "二叉树的中序遍历非递归形式:"<< endl;Inorder(tree);return 0;
}

这篇关于二叉树的创建 先序 中序 后续 递归和非递归遍历的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Python创建Excel的4种方式小结

《Python创建Excel的4种方式小结》这篇文章主要为大家详细介绍了Python中创建Excel的4种常见方式,文中的示例代码简洁易懂,具有一定的参考价值,感兴趣的小伙伴可以学习一下... 目录库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriterwww.cppcns.c

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

Window Server2016 AD域的创建的方法步骤

《WindowServer2016AD域的创建的方法步骤》本文主要介绍了WindowServer2016AD域的创建的方法步骤,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、准备条件二、在ServerA服务器中常见AD域管理器:三、创建AD域,域地址为“test.ly”

Python在固定文件夹批量创建固定后缀的文件(方法详解)

《Python在固定文件夹批量创建固定后缀的文件(方法详解)》文章讲述了如何使用Python批量创建后缀为.md的文件夹,生成100个,代码中需要修改的路径、前缀和后缀名,并提供了注意事项和代码示例,... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5.