14.5二叉树的前序中序后序遍历

在14.4的代码基础上进行实现14.4二叉树层次建树(CLion实现)-CSDN博客

代码: 

function.h代码

//
// Created by admin on 2024/2/28.
//#ifndef INC_1_TREE_FUCTION_H
#define INC_1_TREE_FUCTION_H
#include <stdio.h>
#include <stdlib.h>
//function.h文件定义出结构体
typedef char BiElemType;
typedef struct BiTNode{BiElemType c;	//c就是datastruct BiTNode *lchild;struct BiTNode *rchild;
}BiTNode,*BiTree;//tag结构体是辅助队列使用的
typedef struct tag{BiTree p;	//树的某一个结点的地址值struct tag *pnext;
}tag_t,*ptag_t;
#endif //INC_1_TREE_FUCTION_H

main.cpp代码

#include "fuction.h"
//递归实现
//前序遍历
//abcdefghij前序遍历就是深度优先遍历
void PreOrder(BiTree p)
{if(p!=NULL){printf("%c",p->c);  //打印根结点PreOrder(p->lchild);    //打印左子树PreOrder(p->rchild);    //打印右子树}
}
//中序遍历
void InOrder(BiTree p)
{if(p!=NULL){InOrder(p->lchild);    //打印左子树printf("%c",p->c);  //打印根结点InOrder(p->rchild);    //打印右子树}
}
//后序遍历
void PostOrder(BiTree p)
{if(p!=NULL){PostOrder(p->lchild);    //打印左子树PostOrder(p->rchild);    //打印右子树printf("%c",p->c);  //打印根结点}
}
int main() {//树结构BiTree pnew; //pnew用来申请新的树结点BiTree tree=NULL;	//tree用来指向树根BiElemType c;	//字符类型//辅助队列结构ptag_t phead;	//头指针ptag_t ptail;	//尾指针ptag_t listpnew;//指向新结点的指针ptag_t pcur;	//指向二叉树中父亲结点的指针,用来判断左右孩子是否为空phead=ptail=listpnew=pcur=NULL;	//初始化while(scanf("%c",&c)){if(c=='\n'){break;}//calloc申请的空间大小是两个参数直接相乘,并对空间进行初始化,赋值为0pnew=(BiTree)calloc(1,sizeof(BiTNode));pnew->c=c;listpnew=(ptag_t)calloc(1,sizeof(tag_t));listpnew->p=pnew;//如果是第一个结点if(NULL==tree){tree=pnew;	//tree指向树的根结点phead=ptail=pcur=listpnew; //最开始,所有指针都指向第一个辅助队列结点}else{//让元素入队ptail->pnext=listpnew;ptail=listpnew;//接下来把b结点放入树中if(NULL==pcur->p->lchild){pcur->p->lchild=pnew;}else if(NULL==pcur->p->rchild){pcur->p->rchild=pnew;pcur=pcur->pnext; 	//当前结点左右孩子都有了,pcur就指向下一个}}}printf("------------PreOrder__________\n");//也叫先序遍历,打印当前结点,打印左孩子,打印右孩子PreOrder(tree);printf("\n------------InOrder__________\n");//打印左孩子,打印当前结点,打印右孩子InOrder(tree);printf("\n------------PostOrder__________\n");//打印左孩子,打印右孩子,打印当前结点PostOrder(tree);return 0;
}

SimpleInput:

abcdefghij

SimpleOutput:

------------PreOrder__________ 
abdhiejcfg
------------InOrder__________  
hdibjeafcg
------------PostOrder__________
hidjebfgca

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/504093.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vscode c/c++ 检测到 #include 错误。请更新 includePath。

问题背景 使用vscode打开项目后&#xff0c;头文件显示红色波浪线&#xff0c;没有引入。 检测到 #include 错误。请更新 includePath。已为此翻译单元(xxx)禁用波形曲线。 解决方法 gcc -v -E -x c - 显示所有头文件路径。 打开c_cpp_properties.json文件&#xff0c;粘贴…

UE4 Niagara 关卡3.1官方案例解析二

自己尝试做做&#xff0c;打乱顺序 1、新建空的niagara system&#xff0c;添加空的发射器。更换渲染器为网格体渲染器并添加网格体。 2、发射器更新里面添加Spawn Rate&#xff0c;发射个粒子看看 效果图&#xff1a; 3、采样静态网格体&#xff0c;网格体粒子出生于静态网格…

【Python】Python全国工作岗位数据分析(源码)【独一无二】课程设计

&#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化【获取源码商业合作】 &#x1f449;荣__誉&#x1f448;&#xff1a;阿里云博客专家博主、5…

php源码 单色bmp图片取模工具 按任意方式取模 生成字节数组 自由编辑点阵

http://2.wjsou.com/BMP/index.html 想试试chatGPT4生成&#xff0c;还是要手工改 php 写一个网页界面上可以选择一张bmp图片&#xff0c;界面上就显示这张bmp图片&#xff0c; 点生成取模按钮&#xff0c;在图片下方会显示这张bmp图片的取模数据。 取模规则是按界面设置的&a…

jupyter 用pyecharts进行数据分析

一、jupyter和pyecharts下载和打开 因为我是用的pycharm&#xff0c;所以我直接在pycharm项目终端中下载pip install jupyter,pip install pyecharts 在你下载的项目路径中输入jupyter notebook 之后会进入页面 Jupyter 具体使用参考这个链接&#xff1a;Jupyter Notebook基本…

深入理解变量名与指针:编程语言中的抽象与直接内存访问

深入理解变量名与指针&#xff1a;编程语言中的抽象与直接内存访问 在编程世界里&#xff0c;理解变量名与指针的概念是理解软件是如何与计算机硬件交互的关键。这篇博客旨在深入探讨变量名和指针在不同编程语言中的作用和区别&#xff0c;以及它们在内存管理中的意义。 变量名…

【python】python懂车帝数据可视化(代码+报告)

&#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化【获取源码商业合作】 &#x1f449;荣__誉&#x1f448;&#xff1a;阿里云博客专家博主、5…

windows系统下安装RabbitMQ

一、RabbitMQ安装软件资源准备 因为RabbitMQ是Erlang语言开发的&#xff0c;因此安装Erlang环境在进行安装RbbitMQ的操作&#xff0c;选择两者版本时一定要参考版本的兼容性 1.RabbitMQ国内下载地址&#xff0c;因官网下载比较缓慢&#xff0c;还是国内的稍微快些 https://r…

Kubernetes 杂谈之 configmap \n的问题

一 configmap \n的问题 涉及的知识点&#xff1a; configmap资源对象、yaml|- | >语法目的&#xff1a; 彻底解决YAML 多行文本格式化丢失问题 ① ConfigMap 进阶 configmap 的data中的文件内容格式错乱 ConfigMap多行格式 场景&#xff1a;将业务部署到k8s时,应用的…

牛客禁用题:求阶乘

思路&#xff1a;在新类中使用全局变量进行运算&#xff0c;在主类中定义新类数组&#xff0c;通过构造函数的调用次数返回阶乘 #include <type_traits> class add{public:static int count;static int tmp;add(){countcounttmp;tmp;} }; int add::count0; int add::t…

opencascade c#例程解析

1.编译 将msvc.bat文件拖入vs2022的x64 native tools&#xff0c;即可 2.about.xaml <Windowxmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"x:Class"IE_WPF_WinForms…

欧姆龙PLC使用

安装开发软件 Sysmac Studio 1_7_20》1.5升级包》1.29升级包 许可证 6002-2091-3336-5781 项目启动 1、新建项目&#xff0c;选择对应PLC和开发软件版本号 2、自动创建项目后&#xff0c;可以设置通讯&#xff0c;如OPC和CIP CIP启动与配置 更改IP地址 3、添加全局变量&a…