二叉树的常见算法
时间:2020-01-14
本文章向大家介绍二叉树的常见算法,主要包括二叉树的常见算法使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
二叉树的遍历
- 先序遍历指的就是先访问本节点,再访问该节点的左孩子和右孩子;
- 中序遍历指的就是:先访问左孩子,再访问本节点,最后访问右孩子;
- 后序遍历指的就是:先访问左右孩子,最后访问本节点。
- 层次遍历:按照树的每一层(高度)进行遍历。
深度遍历
- 递归实现:先序、中序、后序
- 非递归实现:先序、中序、后序
层次遍历
深度遍历
递归实现先序、中序、后序
#include <stdio.h> //声明树类型 typedef struct TREEtag TREEtagNode; struct TREEtag { int val; TREEtagNode *left; TREEtagNode *right; }; //访问 void get(TREEtagNode *node){ printf("%d\n",node->val); } //先序遍历 void r1(TREEtagNode *node){ if(node != NULL) { // get(node); // r1(node->left); // r1(node->right); } } //中序遍历 void r2(TREEtagNode *node){ if(node != NULL) { // r2(node->left); // get(node); // r2(node->right); } } //后序遍历 void r3(TREEtagNode *node){ if(node != NULL) { // r3(node->left); // r3(node->right); // get(node); } } int main () { TREEtagNode A0,A1,A2,A3,A4; A0.left = &A1; A0.right = &A2; A0.val = 10; A1.left = &A3; A1.right = NULL; A1.val = 2; A2.left = &A4; A2.right = NULL; A2.val = 7; A3.left = NULL; A3.right = NULL; A3.val = 5; A4.left = NULL; A4.right = NULL; A4.val = 9; printf("初始化成功\n"); printf("先序遍历:\n"); r1(&A0); printf("中序遍历:\n"); r2(&A0); printf("后序遍历:\n"); r3(&A0); return 0; }
初始化成功 先序遍历: 10 2 5 7 9 中序遍历: 5 2 10 9 7 后序遍历: 5 2 9 7 10
非递归实现:先序、中序、后序
#include <stdio.h> //声明树类型 typedef struct TREEtag TREEtagNode; struct TREEtag { int val; TREEtagNode *left; TREEtagNode *right; }; //访问 void get(TREEtagNode *node){ printf("%d\n",node->val); } #define Size 10 typedef struct stacktag { TREEtagNode *a[Size]; int top; }stack; //先序遍历 void r4(TREEtagNode *node){ if(node != NULL) { //初始化栈 stack Stack; Stack.top = -1; //初始化临时节点 TREEtagNode *p; //把根节点插入栈 Stack.a[++Stack.top] = node; //开始遍历 while(Stack.top != -1) { //取出元素 p = Stack.a[Stack.top--]; //操作 get(p); //存储元素:判断当前节点的左右节点是否存在,如果存在,则先存右元素,后存左元素 if(p->right != NULL) Stack.a[++Stack.top] = p->right; if(p->left != NULL) Stack.a[++Stack.top] = p->left; } } } //中序遍历 void r5(TREEtagNode *node){ if(node != NULL) { //初始化栈 stack Stack; Stack.top = -1; //初始化临时节点 TREEtagNode *p = NULL; p = node; //开始遍历 while(Stack.top != -1 || p != NULL) { while(p != NULL) { Stack.a[++Stack.top] = p; p = p->left; } if(Stack.top != -1) { p = Stack.a[Stack.top--]; //操作 get(p); p = p->right; } } } } //双栈法后序遍历 void r6(TREEtagNode *node){ if(node != NULL) { //初始化栈 stack Stack1; Stack1.top = -1; stack Stack2; Stack2.top = -1; //初始化临时节点 TREEtagNode *p; //把根节点插入栈 Stack1.a[++Stack1.top] = node; //开始遍历 while(Stack1.top != -1) { //取出元素 p = Stack1.a[Stack1.top--]; Stack2.a[++Stack2.top] = p; //存储元素:判断当前节点的左右节点是否存在,如果存在,则先存右元素,后存左元素 if(p->left != NULL) Stack1.a[++Stack1.top] = p->left; if(p->right != NULL) Stack1.a[++Stack1.top] = p->right; } while(Stack2.top != -1) { p = Stack2.a[Stack2.top--]; //操作 get(p); } } } int main () { TREEtagNode A0,A1,A2,A3,A4; A0.left = &A1; A0.right = &A2; A0.val = 10; A1.left = &A3; A1.right = NULL; A1.val = 2; A2.left = &A4; A2.right = NULL; A2.val = 7; A3.left = NULL; A3.right = NULL; A3.val = 5; A4.left = NULL; A4.right = NULL; A4.val = 9; printf("初始化成功\n"); printf("先序遍历:\n"); r4(&A0); printf("中序遍历:\n"); r5(&A0); printf("后序遍历:\n"); r6(&A0); return 0; }
初始化成功 先序遍历: 10 2 5 7 9 中序遍历: 5 2 10 9 7 后序遍历: 5 2 9 7 10
原文地址:https://www.cnblogs.com/-wenli/p/12193170.html
- [C#6] 2-nameof 运算符
- Key-Value Coding(KVC),Key-Value Observing(KVO)和Cocoa Bindings for MonoMac
- [C#6] 7-索引初始化器
- jquery mobile 移动web(3)
- 卷积神经网络详解(二)——自己手写一个卷积神经网络
- VS 2010 SP1的一个功能(添加可部署依赖项)
- 一组扁平化组件推荐下载(PSD 格式)
- [C#6] 6-表达式形式的成员函数
- 在启用了IPV6的机器上获取客户端ipv4地址
- 使用 MDT 2010 进行可伸缩部署
- 性能优化工具 MVC Mini Profiler
- 在ASP.NET应用启动的时候初始化的几种方法
- [C#6] 8-异常增强
- 信息超新星的诞生
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法