二叉树非递归遍历(c语言)

article/2025/9/22 17:00:02

在这里插入图片描述
结果如下图:
在这里插入图片描述
#号代表NULL,此时没有节点
一、在c语言中进行二叉树的非递归遍历需要用到栈,而在c语言中没有直接调用栈的接口,所以在实现非递归遍历时需要先实现一个栈,需要用到出栈入栈栈顶元素判断栈是否为空,这四个接口,别的可以不用实现。
二、 实现栈的接口
注意:这里栈的数组需要用到的类型时Node 类型的,所以先把二叉树节点Node定义出来才能才能使用Node这个类型

typedef struct Node//定义树的一个节点
{struct Node *_left;struct Node *_right;BDataType _data;
}Node;

进行栈的接口实现

typedef Node* SDataType;
typedef struct stack//定义栈
{SDataType *_array;int _count;//总容量大小int _size;//当前元素大小
}stack;
void stackInit(stack *st)//栈的初始化
{st->_array = (SDataType*)malloc(sizeof(SDataType)*num);st->_count = num;st->_size = 0;
}
void stackInsert(stack *st, SDataType value)//入栈
{if (st->_size == st->_count)//空间已满,需要扩容{st->_array = (SDataType*)realloc(st->_array, sizeof(SDataType)*(2 * st->_count));st->_count = 2 * st->_count;}st->_array[st->_size] = value;st->_size++;
}
void stackDel(stack *st)//出栈
{if (st->_size == 0){printf("栈以为空,不能出栈!!!\n");}st->_size--;
}SDataType stackTop(stack *st)//获取栈顶元素
{return st->_array[st->_size - 1];
}
int stackEmpty(stack *st)//判断栈是否为空
{if (st->_size == 0){return 1;}return 0;
}

三、创建一棵树
可以用前序遍历去创建一棵树
这里的#号是代表NULL的,不太懂怎样建树的可以先把牛客上的一道题做完之后就会用各种方法去建树了,
链接在这:https://www.nowcoder.com/practice/4b91205483694f449f94c179883c1fef?tpId=60&&tqId=29483&rp=1&ru=/activity/oj&qru=/ta/tsing-kaoyan/question-ranking

Node *TreeCreat(BDataType *array, int *pos)//创建一棵树,后面会对这棵树进行各种排序
{if (array[*pos] != '#'){Node *root = (Node *)malloc(sizeof(Node));root->_data = array[*pos];(*pos)++;root->_left = TreeCreat(array, pos);(*pos)++;root->_right = TreeCreat(array, pos);return root;}else{return NULL;}
}

四、非递归去实现三种遍历
1、前序遍历
先遍历当前节点的最左路径,再遍历最后访问节点的右子树

void preOrder(Node *root)//前序遍历非递归
{printf("前序遍历#: ");stack st;stackInit(&st);Node *cur = root;Node *top;while (cur || stackEmpty(&st) != 1){//从当前根的位置,一直遍历完最左路径while (cur){printf("%c ", cur->_data);stackInsert(&st, cur);cur = cur->_left;}//获取栈顶元素top = stackTop(&st);stackDel(&st);//访问右子树cur = top->_right;}printf("\n");
}

2、中序遍历
当前节点先压栈不能访问,只有左子树访问完之后,才能访问最后压栈的节点以及他的右子树

void MidOrder(Node *root)//中序遍历非递归
{printf("前序遍历#: ");stack st;stackInit(&st);Node *cur = root;Node *top;while (cur || stackEmpty(&st) != 1){while (cur){stackInsert(&st, cur);cur = cur->_left;}top = stackTop(&st);stackDel(&st);printf("%c ", top->_data);cur = top->_right;}printf("\n");
}

3、后序遍历
后序遍历相对于前两种有点麻烦,看不懂了可以私聊我

void EndOrder(Node *root)//后序遍历非递归
{printf("前序遍历#: ");stack st;stackInit(&st);Node *cur = root;Node *top;Node *prev = NULL;while (cur || stackEmpty(&st) != 1){while (cur){stackInsert(&st, cur);cur = cur->_left;}top = stackTop(&st);if (top->_right == NULL || top->_right == prev){printf("%c ", top->_data);stackDel(&st);prev = top;}else{cur = top->_right;}}printf("\n");
}

代码如下

#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)
//定义一个栈可以实现入栈出栈获取栈顶元素的操作
#define num 10
typedef char BDataType;
typedef struct Node//定义树的一个节点
{struct Node *_left;struct Node *_right;BDataType _data;
}Node;
typedef Node* SDataType;
typedef struct stack//定义栈
{SDataType *_array;int _count;//总容量大小int _size;//当前元素大小
}stack;
void stackInit(stack *st)//栈的初始化
{st->_array = (SDataType*)malloc(sizeof(SDataType)*num);st->_count = num;st->_size = 0;
}
void stackInsert(stack *st, SDataType value)//入栈
{if (st->_size == st->_count)//空间已满,需要扩容{st->_array = (SDataType*)realloc(st->_array, sizeof(SDataType)*(2 * st->_count));st->_count = 2 * st->_count;}st->_array[st->_size] = value;st->_size++;
}
void stackDel(stack *st)//出栈
{if (st->_size == 0){printf("栈以为空,不能出栈!!!\n");}st->_size--;
}SDataType stackTop(stack *st)//获取栈顶元素
{return st->_array[st->_size - 1];
}
int stackEmpty(stack *st)//判断栈是否为空
{if (st->_size == 0){return 1;}return 0;
}
//用栈来实现二叉树的非递归的三种遍历方法
//先创建一个树
Node *TreeCreat(BDataType *array, int *pos)//创建一棵树,后面会对这棵树进行各种排序
{if (array[*pos] != '#'){Node *root = (Node *)malloc(sizeof(Node));root->_data = array[*pos];(*pos)++;root->_left = TreeCreat(array, pos);(*pos)++;root->_right = TreeCreat(array, pos);return root;}else{return NULL;}
}
//1、前序遍历
void preOrder(Node *root)//前序遍历非递归
{printf("前序遍历#: ");stack st;stackInit(&st);Node *cur = root;Node *top;while (cur || stackEmpty(&st) != 1){while (cur){printf("%c ", cur->_data);stackInsert(&st, cur);cur = cur->_left;}top = stackTop(&st);stackDel(&st);cur = top->_right;}printf("\n");
}
//2、中序遍历
void MidOrder(Node *root)//中序遍历非递归
{printf("前序遍历#: ");stack st;stackInit(&st);Node *cur = root;Node *top;while (cur || stackEmpty(&st) != 1){while (cur){stackInsert(&st, cur);cur = cur->_left;}top = stackTop(&st);stackDel(&st);printf("%c ", top->_data);cur = top->_right;}printf("\n");
}
//3、后序遍历
void EndOrder(Node *root)//后序遍历非递归
{printf("前序遍历#: ");stack st;stackInit(&st);Node *cur = root;Node *top;Node *prev = NULL;while (cur || stackEmpty(&st) != 1){while (cur){stackInsert(&st, cur);cur = cur->_left;}top = stackTop(&st);if (top->_right == NULL || top->_right == prev){printf("%c ", top->_data);stackDel(&st);prev = top;}else{cur = top->_right;}}printf("\n");
}
int main()
{BDataType array[100];//定义一个char数组scanf("%s", array);int pos = 0;Node *root = TreeCreat(array, &pos);preOrder(root);//前序遍历MidOrder(root);//中序遍历EndOrder(root);//后序遍历system("pause");return 0;
}

http://chatgpt.dhexx.cn/article/KHNI19F3.shtml

相关文章

二叉树非递归遍历实现(Java)

首先理解一下二叉树节点结构。left指向左节点&#xff0c;right指向右节点&#xff0c;val为节点中的值。 class TreeNode {int val;TreeNode left;TreeNode right;public TreeNode(int x) {val x;}} 先序遍历 //非递归先序遍历&#xff08;需一个辅助栈&#xff0c;顺序为根…

二叉树遍历的一些非递归算法

二叉树的非递归算法因为涉及到栈和队列&#xff0c;所以写的时候总是受到伪代码的干扰&#xff0c;要完整的补全栈和队列的结构有些麻烦&#xff0c;这里借鉴了一些大佬的思想&#xff0c;发现可以直接在树中模拟栈和队列的存在&#xff0c;这给非递归的完整代码带来了很大的便…

三种非递归遍历二叉树的方法

就以这个树为例&#xff0c;来讲讲二叉树的非递归遍历。 先序遍历&#xff1a; 先序遍历结果为3 4 6 5 8 9&#xff0c;就拿树的左枝为例&#xff0c;3是根&#xff0c;打印&#xff0c;4是3的左孩子&#xff0c;打印&#xff0c;6是4的左孩子&#xff0c;打印&#xff0c;6的…

二叉树的非递归遍历

目录 一.前序遍历&#xff08;根左右&#xff09; 1.思路图解 2.代码 二.中序遍历&#xff08;左根右&#xff09; 1.思路图解 2.代码 三.后序遍历&#xff08;左右根&#xff09; 1.思路图解 2.代码 四.层序遍历 1.思路图解 2.代码 一.前序遍历&#xff08;根左右…

smile——Java机器学习引擎

介绍 Smile&#xff08;统计机器智能和学习引擎&#xff09;是一个基于Java和Scala的快速、全面的机器学习、NLP、线性代数、图形、插值和可视化系统。 凭借先进的数据结构和算法&#xff0c;Smile提供了最先进的性能。Smile有很好的文档记录&#xff0c;请查看项目网站以获取…

Java机器学习库(Java ML)(一、分类)

本文章翻译至Java ML技术文档classification.pdf&#xff0c;代码部分是参考该文档使用IDEA编写&#xff0c;同时加入了运行结果。 分类 本文介绍与分类相关的功能。 该文章假设您已熟悉Java ML的基础知识&#xff0c;如入门教程中所述&#xff08;http://java-ml.sourcefor…

目前流行的、强大的基于Java的机器学习开发库精选

图片来源: Mindfire Solutions 现如今&#xff0c;拥有深度学习和机器学习领域的技术是科技界的趋势之一&#xff0c;并且企业则希望雇佣一些拥有良好的机器学习知识背景的程序开发工程师。本文将介绍一些目前流行的、强大的基于Java的机器学习库&#xff0c;希望给大家带来帮助…

JAVA 人工神经网络实现,机器学习,人工智能

人工智能&#xff08;AI&#xff09; 、机器学习&#xff08;ML&#xff09;、深度学习&#xff08;DL&#xff09;、神经网络&#xff08;CNN&#xff09; IT技术圈的人怼这些词汇大家都一定耳熟能详了&#xff0c;可能圈外的也不陌生&#xff0c;但是作为一个作为一个“攻城…

机器学习java_如何开始使用Java机器学习

机器学习java 什么是开始使用Java机器学习的最佳工具&#xff1f; 他们已经存在了一段时间&#xff0c;但如今看来&#xff0c;每个人都在谈论人工智能和机器学习。 对于科学家和研究人员而言&#xff0c;它已经不再是秘密&#xff0c;几乎可以在任何新兴技术中实现。 在下面…

谁说搞Java的不能玩机器学习?

简介 机器学习在全球范围内越来越受欢迎和使用。 它已经彻底改变了某些应用程序的构建方式&#xff0c;并且可能会继续成为我们日常生活中一个巨大的&#xff08;并且正在增加的&#xff09;部分。没有什么包装且机器学习并不简单。 它对许多人来说似乎非常复杂并常常令人生畏…

基于 Java 机器学习自学笔记 (第51-53天:kNN)

注意&#xff1a;本篇为50天后的Java自学笔记扩充&#xff0c;内容不再是基础数据结构内容而是机器学习中的各种经典算法。这部分博客更侧重与笔记以方便自己的理解&#xff0c;自我知识的输出明显减少&#xff0c;若有错误欢迎指正&#xff01; 目录 一、关于数据集及其导入…

基于 Java 机器学习自学笔记 (第66至68天:主动学习之ALEC)

注意&#xff1a;本篇为50天后的Java自学笔记扩充&#xff0c;内容不再是基础数据结构内容而是机器学习中的各种经典算法。这部分博客更侧重于笔记以方便自己的理解&#xff0c;自我知识的输出明显减少&#xff0c;若有错误欢迎指正&#xff01; 目录 前言 一、关于学习的分类…

超全!基于Java的机器学习项目、环境、库...

https://yq.aliyun.com/articles/278837?utm_sourcetuicool&utm_mediumreferral 摘要&#xff1a; 你是一名希望开始或者正在学习机器学习的Java程序员吗&#xff1f; 利用机器学习编写程序是最佳的学习方式。你可以从头开始编写算法&#xff0c;但是利用现有的开源库&am…

结合Java和机器学习技术,如何驾驭大数据提升业务效率和竞争力?

随着大数据的不断增长和发展&#xff0c;越来越多的企业和组织开始关注如何利用大数据来提高业务效率和竞争力。在大数据分析领域&#xff0c;Java和机器学习技术是两个非常重要的方向。本文将介绍这两个技术的基本概念、应用场景和发展趋势&#xff0c;并重点探讨如何结合Java…

25个JAVA 机器学习工具包

本列表总结了25个Java机器学习工具&库&#xff1a; 1. Weka集成了数据挖掘工作的机器学习算法。这些算法可以直接应用于一个数据集上或者你可以自己编写代码来调用。Weka包括一系列的工具&#xff0c;如数据预处理、分类、回归、聚类、关联规则以及可视化。 2.Massive Onli…

7个最好的Java机器学习开发库

IT派 - {技术青年圈} 持续关注互联网、区块链、人工智能领域 摘要&#xff1a; 本文将介绍一些目前流行的、强大的基于Java的机器学习库。 图片来源: Mindfire Solutions 摘要&#xff1a;现如今&#xff0c;拥有深度学习和机器学习领域的技术是科技界的趋势之一&#xff0c;并…

基于 Java 机器学习自学笔记 (第71-73天:BP神经网络)

注意&#xff1a;本篇为50天后的Java自学笔记扩充&#xff0c;内容不再是基础数据结构内容而是机器学习中的各种经典算法。这部分博客更侧重于笔记以方便自己的理解&#xff0c;自我知识的输出明显减少&#xff0c;若有错误欢迎指正&#xff01; 前言 本文是我计划描述BP神经网…

如何开始Java机器学习

什么是开始使用Java机器学习的最佳工具&#xff1f; 他们已经存在了一段时间&#xff0c;但如今看来&#xff0c;每个人都在谈论人工智能和机器学习。 对于科学家和研究人员而言&#xff0c;它已不再是秘密&#xff0c;几乎可以在任何新兴技术中实现。 在下面的文章中&#x…

如何开始使用 Java 机器学习

开始Java机器学习的最好工具是什么&#xff1f; 这个问题已经有一段时间了&#xff0c;但最近这些日子几乎每个人都在谈论人工智能和机器学习。这已经不再是一个保留给科学家和研究者的秘密&#xff0c;而是几乎实现于每一项新兴技术中。 在下面的章节中&#xff0c;我们会做一…

6大最常用的Java机器学习库一览

导读&#xff1a;机器学习是目前盛行于世的技术之一&#xff0c;这几年一时风头无两。虽然在机器学习中&#xff0c;Python是人工智能从业者使用最多的编程语言&#xff0c;但是&#xff0c;Java 在项目开发中仍然发挥着不可替代的作用&#xff0c;而且许多流行的机器学习框架本…