【考研数据结构代码题6】构建二叉树及四大遍历(先中后层)

题目:请你编写完整的程序构建一棵二叉树并对其进行先序遍历、中序遍历、后序遍历与层次遍历,分别打印并输出遍历结果

难度:★★★

二叉树的存储结构

    typedef struct Node{char data;//数据域struct Node* left;//左子树struct Node* right;//右子树}BiNode,*BiTree;//二叉链表

二叉树的构建

        按照先序遍历的的顺序逐个输入结点的值来构建二叉树,其中,以字符‘#’表示该结点为叶子结点,即没有左右孩子,递归地构建左子树与右子树。

void  CreateBiTree(BiTree &T)
{//按先序序列输入二叉树中的结点值 char key; printf("请先序输入字符:");scanf("%c",&key);//输入#代表该结点为叶子结点,结束插入if(key == '#')  T = NULL;else{//分配空间创建新结点 T = (BiNode*) malloc (sizeof(BiNode));T->data = key;CreateBiTree(T->left) ; //构造左子树CreateBiTree(T->right) ;//构造右子树 }
}

 二叉树先序遍历

//先序遍历(根左右)
void PreOrder(BiTree T){if(T){visit(T);PreOrder(T->left);PreOrder(T->right);}
} 

 二叉树中序遍历

//中序遍历(左根右)
void InOrder(BiTree T){if(T){InOrder(T->left);visit(T);InOrder(T->right);}
} 

 二叉树后序遍历

//后序遍历(左右根)
void PostOrder(BiTree T){if(T){PostOrder(T->left);PostOrder(T->right);visit(T);}
} 

  二叉树层次遍历

//层次遍历(自上而下,从左到右)
void LevelOrder(BiTree T){InitQueue(Q);//初始化一个队列BiTree p;//p为当前遍历的结点EnQueue(Q,p);//根节点入队while(!IsEmpty(Q)){DeQueue(Q,p);visit(p);if(p->left!=NULL){//左孩子入队EnQueue(Q,p->left); }if(p->right!=NULL){//右孩子入队EnQueue(Q,p->right); }} 
} 

完整代码

#include<iostream>
#include<stdlib.h>
#include<queue>
using namespace std;
typedef struct Node{char data;struct Node* left;struct Node* right;
}BiNode,*BiTree;//构建二叉树 
void  CreateBiTree(BiTree &T)
{//按先序序列输入二叉树中的结点值 char key; printf("请先序输入字符:");scanf("%c",&key);//输入#代表该结点为叶子结点,结束插入if(key == '#')  T = NULL;else{//分配空间创建新结点 T = (BiNode*) malloc (sizeof(BiNode));T->data = key;CreateBiTree(T->left) ; //构造左子树CreateBiTree(T->right) ;//构造右子树 }
}//访问并输出根结点
void visit(BiTree T){cout<<T->data<<" ";
} //先序遍历:DLR 
void PreOrder(BiTree T){if(T){visit(T);PreOrder(T->left);PreOrder(T->right);}
} //中序遍历:LDR
void InOrder(BiTree T){if(T){InOrder(T->left);visit(T);InOrder(T->right);}
} //后序遍历:LRD
void PostOrder(BiTree T){if(T){PostOrder(T->left);PostOrder(T->right);visit(T);}
} //层序遍历
void LevelOrder(BiTree T){if(T==NULL) return ;queue<BiTree>que;que.push(T);while(!que.empty()){BiTree ptr=que.front();cout<<ptr->data<<" ";que.pop();if(ptr->left!=NULL)que.push(ptr->left);if(ptr->right!=NULL)que.push(ptr->right);}
} int main(){BiTree T;CreateBiTree(T);cout<<"二叉树构建完成!"<<endl;cout<<"先序遍历:";PreOrder(T);cout<<endl;cout<<"中序遍历:";InOrder(T);cout<<endl;cout<<"后序遍历:";PostOrder(T);cout<<endl;cout<<"层序遍历:";LevelOrder(T);cout<<endl;return 0;
} 

机算结果

手算结果

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

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

相关文章

【评论送书】十本架构师成长和软件架构技术相关的好书(可以任选)

正文开始前给大家推荐个网站&#xff0c;前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 参与规则 本次送书1~5本参与方式&#xff1a;关注博主、点赞、收藏、评论&#xff08;从评论区…

[工业自动化-18]:西门子S7-15xxx编程 - 软件编程 - PLC用于工业领域的嵌入式系统:硬件原理图、指令系统、系统软件架构、开发架构等

目录 前言&#xff1a; 一、PLC的硬件电路原理 1.1 硬件框图 1.2 硬件模块详解 &#xff08;1&#xff09;CPU &#xff08;2&#xff09;存储器 &#xff08;3&#xff09;输入/输出&#xff08;I/O&#xff09;模块 &#xff08;4&#xff09;编程器 &#xff08;5&a…

Flume(一)【Flume 概述】

前言 今天实在不知道学点什么好了&#xff0c;早上学了3个多小时的 Flink &#xff0c;整天只学一门技术是很容易丧失兴趣的。那就学点新的东西 Flume&#xff0c;虽然 Kafka 还没学完&#xff0c;但是大数据生态圈的基础组件也基本就剩这倆了。 Flume 概述 生产环境中的数据一…

一道 python 数据分析的题目

python 数据分析的题目。 做题方法&#xff1a;使用 pandas 读取数据&#xff0c;然后分析。 知识点&#xff1a;pandas&#xff0c;正则表达式&#xff0c;py知识。 过程&#xff1a;不断使用 GPT&#xff0c;遇到有问题的地方自己分析&#xff0c;把分析的结果告诉 GPT&am…

深入了解HTTP与HTTPS关键差异与底层原理

文章目录 历史发展HTTP的历史发展&#xff1a;HTTPS的历史发展&#xff1a; HTTP与HTTPS的区别和联系HTTP与HTTPS的底层原理HTTP的底层原理&#xff1a;HTTPS的底层原理&#xff1a; HTTP与HTTPS的协议组成HTTP协议的组成部分&#xff1a;HTTPS协议的组成部分&#xff1a;TLS&a…

Java多线程入门

进程与线程 **进程&#xff1a;**每个进程都有独立的代码和数据空间&#xff08;进程上下文&#xff09;&#xff0c;进程间的切换会有较大的开销&#xff0c;一个进程包含1–n个线程。&#xff08;进程是资源分配的最小单位&#xff09; **线程&#xff1a;**同一类线程共享代…

点成方案丨使用细胞计数仪监控CAR-T细胞疗法的生产

一、概述 嵌合抗原受体&#xff08;CAR&#xff09;是经过改造后赋予T细胞靶向特定抗原的新能力的受体蛋白。这些受体是嵌合的&#xff0c;因为它们将抗原结合和T细胞激活功能结合到一个受体中。CAR-T细胞疗法使用经过CAR改造的T细胞来治疗癌症。CAR-T免疫疗法的前提是修改T细…

PHP原生类总结利用

SPL介绍 SPL就是Standard PHP Library的缩写。据手册显示&#xff0c;SPL是用于解决典型问题(standard problems)的一组接口与类的集合。打开手册&#xff0c;正如上面的定义一样&#xff0c;有许多封装好的类。因为是要解决典型问题&#xff0c;免不了有一些处理文件…

如何使用iPhone15在办公室观看家里电脑上的4k电影?

如何使用iPhone15在办公室观看家里电脑上的4k电影&#xff1f; 文章目录 如何使用iPhone15在办公室观看家里电脑上的4k电影&#xff1f;1.使用环境要求&#xff1a;2.下载群晖videostation&#xff1a;3.公网访问本地群晖videostation中的电影&#xff1a;4.公网条件下使用电脑…

论文浅尝 | 用于开放式文本生成的事实增强语言模型

笔记整理&#xff1a;李煜&#xff0c;东南大学硕士&#xff0c;研究方向为知识图谱 链接&#xff1a;https://proceedings.neurips.cc/paper_files/paper/2022/hash/df438caa36714f69277daa92d608dd63-Abstract-Conference.html 1. 动机 生成式语言模型&#xff08;例如 GPT-3…

CNCC 2023收官,Milvus Cloud与行业大咖共话向量数据库系统

近期,CNCC 2023 在沈阳圆满结束,紧凑、前沿的 129 场技术论坛让人印象深刻。据悉,这 129 场技术论坛涵盖人工智能、安全、计算+、软件工程、教育、网络、芯片、云计算等 30 余个方向。Zilliz 受邀参与【智能时代的大数据系统】技术论坛。 智能时代的到来,无疑给社会经济和日…

【深度学习】SimSwap: An Efficient Framework For High Fidelity Face Swapping 换脸,实战

代码&#xff1a;https://github.com/neuralchen/SimSwap 文章目录 摘要介绍RELATED WORK实验结论代码实操 SimSwap是一个高保真度人脸交换的高效框架。它将源脸的身份转移到目标脸上&#xff0c;同时保留目标脸的属性。该框架包括ID注入模块&#xff08;IIM&#xff09;&#…

linux网络流量数据统计

两种方法&#xff1a; 1.ifcong来进行获取 2. [rootnode1 shell]# cat /proc/net/dev Inter-| Receive | Transmitface |bytes packets errs drop fifo frame compressed multicast|bytes packets errs drop fifo co…

Avatar虚拟形象解决方案,趣味化的视频拍摄与直播新体验

企业们正在寻找新的方式来吸引和保持观众的注意力,一种新兴的解决方案就是使用Avatar虚拟形象技术&#xff0c;这种技术可以让用户在视频拍摄或直播场景中&#xff0c;以自定义的数字人形象出现&#xff0c;同时保持所有的表情和脸部驱动。美摄科技正是这个领域的领军者&#x…

Redhat Linux v8.2 实时内核环境配置及参数调优

Redhat-Linux V8.2 实时内核环境配置及参数调优 -------物理机 & 虚拟机 一、前言 本文档包含有关Redhat Linux for Real Time的基本安装和调试信息。许多行业和组织需要极高性能的计算&#xff0c;并且可能需要低且可预测的延迟&#xff0c;尤其是在金融和电信行业中。延…

[RK-Linux] updateEngine工具使用以及代码分析

Rockchip Linux 平台支持两种启动方案,Recovery 模式和Linux A/B 模式: Recovery 模式,设备上有一个单独的分区(recovery)用于升级操作。Linux A/B 模式,设备上有两套固件,可切换使用。两种启动方案的对比如下: 升级方案代码路径是否支持Recovey启动模式升级是否支持A/B启…

【工艺库】SMIC数字后端工艺库

工艺库文件 Calibredigital文件夹apollolefprimetimesynopsys TD系列文件夹 本来是想找一个工艺库&#xff0c;想要其包含逻辑综合和SPICE Model相关的库文件&#xff0c;但是找了很久也没有直接找到想要的&#xff0c;主要原因还是自己对工艺库文件的构成不是很清楚&#xff0…

小程序样式问题

小程序切换下一个文章或者页面&#xff0c;淡入淡出效果 // detail.js getArticleData: function(articleId) {// 开始淡出效果this.animate(.detail-page, [{ opacity: 1.0, ease: ease-out },{ opacity: 0.0, ease: ease-out }], 500, () > {// 在淡出动画完成后请求文章…

《QT从基础到进阶·二十六》绘制多个图形项(QGraphicsRectItem,QGraphicsLineItem,QGraphicsPolygonItem)

这个demo用QT实现了对多个图形项的绘制&#xff0c;包括矩形的绘制&#xff0c;直线的绘制和多边形的绘制&#xff0c;是之前一章中绘制矩形的增强版&#xff0c;之前一章节关于矩形的绘制可以参考&#xff1a;《QT从基础到进阶十五》用鼠标绘制矩形&#xff08;QGraphicsView、…

Web安全:Vulfocus 靶场搭建.(漏洞集成平台)

Web安全&#xff1a;Vulfocus 靶场搭建.&#xff08;漏洞集成平台&#xff09; Vulfocus 是一个包含了多种漏洞靶场的镜像。每个靶场都有具体的漏洞环境和攻击点。Vulfocus 的靶场包括了 Web 安全漏洞、系统安全漏洞、网络安全漏洞、密码学漏洞等多种类型。通关这个靶场我们可以…