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

news2024/10/6 10:33:45

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

难度:★★★

二叉树的存储结构

    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.coloradmin.cn/o/1211941.html

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

相关文章

Masked Relation Learning for DeepFake Detection

一、研究背景 1.现有deepfake检测方法大多关注于局部伪影或面部不协调&#xff0c;较少挖掘局部区域间的关系。 2.现有关系挖掘类的工作往往忽略了关系信息的传播。 3.遮挡建模在减轻信息冗余的同时促进高级语义信息&#xff08;诱导性偏差较小&#xff09;的挖掘&#xff0c;有…

java常用的几个图片处理工具对Tiff文件的支持

ImageMagick 官网 https://imagemagick.org/&#xff0c; 支持多种格式。命令行工具很适合调试。功能很强大. 还有一款工具GraphicsMagick 是从ImageMagick的基础上研发出来的。 OpenCV 官网 https://opencv.org/ &#xff0c; github地址https://github.com/opencv/opencv&…

ruoyi若依前端请求接口超时,增加响应时长

问题&#xff1a; 前端查询请求超时 解决&#xff1a; 找到request.js的timeout属性由10秒改成了20秒&#xff0c;因为默认是10秒&#xff0c;请求肯定是超出了10秒 祝您万事顺心&#xff0c;没事点个赞呗&#xff0c;关注一下也行啊&#xff0c;有啥要求您评论哈

父组件用ref获取子组件数据

子组件 Son/index.vue 子组件的数据和方法一定要记得用defineExpose暴露&#xff0c;不然父组件用ref是获取不到的&#xff01;&#xff01;&#xff01; <script setup> import { ref } from "vue"; const sonNum ref(1); const changeSon () > {sonNum.…

FSOD论文阅读 - 基于卷积和注意力机制的小样本目标检测

来源:知网 标题:基于卷积和注意力机制的小样本目标检测 作者:郭永红&#xff0c;牛海涛&#xff0c;史超&#xff0c;郭铖 郭永红&#xff0c;牛海涛&#xff0c;史超&#xff0c;郭铖&#xff0e;基于卷积和注意力机制的小样本目标检测 [J/OL]&#xff0e;兵工学报. https://…

行情分析——加密货币市场大盘走势(11.15)

大饼按照预期等待下跌即可&#xff0c;现在已经下跌到35500&#xff0c;昨日晚上跌破了35000&#xff0c;现在放心大胆空。笔者现在都是空单在手。 空单策略&#xff1a;入场36000附近 止盈34000-32000 止损39000 以太昨日策略进场&#xff0c;已经止盈了&#xff0c;最低跌到…

记录我常用的免费API接口

目录 1.随机中英文句子 2.随机中英文句子&#xff08;带图片和音频&#xff09; 3.随机一句诗 4.随机一句话 5.随机一句情话 6. 随机一句舔狗语录 7.历史上的今天 8.获取来访者ip地址 9&#xff1a;获取手机号信息 10. 垃圾分类查询 11.字典查询 12.QQ信息查询 1.随…

RFID技术在危险废物管理中的应用解决方案

一、背景介绍 随着我国经济的快速发展&#xff0c;轻纺、化工、制药、电子等行业的危险废物排放量逐年增加。然而&#xff0c;由于危险废弃物处理不当&#xff0c;可能导致大气、水体和土壤污染&#xff0c;对环境和人体健康造成严重威胁&#xff0c;制约了经济和健康的可持续…

Docker Rootfs

一、rootfs 介绍 rootfs 是一个操作系统所包含的文件、配置和目录&#xff0c;并不包括操作系统内核。在 Linux 操作系统中&#xff0c;这两部分是分开存放的&#xff0c;操作系统只有在开机启动时才会加载指定版本的内核镜像。 实际上&#xff0c;同一台机器上的所有容器&am…

墨西哥专线一次最多发几条柜?

墨西哥专线一次最多发几条柜这个问题涉及到海运业务中的一些复杂因素。墨西哥是一个重要的贸易国家&#xff0c;其与美国和加拿大之间的贸易往来非常频繁&#xff0c;因此海运业务也非常活跃。在墨西哥专线上&#xff0c;一次最多发几条柜通常取决于以下几个因素&#xff1a; 1…

4+糖酵解+预后模型,结合预后模型为文章加分,思路值得模仿

今天给同学们分享一篇生信文章“A glycolysis-related two-gene risk model that can effectively predict the prognosis of patients with rectal cancer”&#xff0c;这篇文章发表在Hum Genomics期刊上&#xff0c;影响因子为4.5。 结果解读&#xff1a; COAD和READ之间的…

模组知识(1)-CRA-光学知识

&#xff03;灵感&#xff03; CRA算是光学基础知识的一部分&#xff0c;而且最近项目确实color shading 挺严重的。以前记的知识不全&#xff0c;这次再次整理一下。常学常新。 目录 sensor CRA&#xff1a; CRA &#xff1a; Lens CRA: lens CRA和sensor CRA不同大小关…

python基于图卷积神经网络GCN模型开发构建文本数据分类模型(以论文领域数据为例)

GCN&#xff08;Graph Convolutional Network&#xff09;图卷积神经网络是一种用于处理图数据的深度学习模型。它是基于图结构的卷积操作进行信息传递和特征学习的。 GCN模型的核心思想是通过利用邻居节点的特征来更新中心节点的表示。它通过迭代地聚集邻居节点的信息&#x…

百望云斩获“新华信用金兰杯”ESG优秀案例 全面赋能企业绿色数字化

近年来&#xff0c;中国ESG蓬勃发展&#xff0c;在政策体系构建、ESG信披ESG投资和国际合作等方面都取得了阶段性成效&#xff0c;ESG生态不断完善。全社会对ESG的认识及实践也在不断深化&#xff0c;ESG实践者的队伍在不断发展壮大。 ESG作为识别企业高质量发展的重要指标&…

2023年 华为杯数学建模 E题

本科大三的时候&#xff0c;打过一次美赛&#xff0c;当时租了一个民宿&#xff0c;和队友一起度过了专注的四天。当时比赛结束之后&#xff0c;拿着手机&#xff0c;看到四天没回的消息&#xff0c;四天没刷过的朋友圈&#xff0c;有种很新奇的感觉&#xff0c;谢谢美赛给了我…

AM335x核心板LCD信号导致DDR3内存不稳定

调试核心板时&#xff0c;碰到了点问题&#xff0c;DDR3内存始终不稳定&#xff0c;经过仔细调试&#xff0c;发现只要打开LCD显示&#xff0c;DDR3的数据就不定期的会有错误。为此单独在boot下做过内存测试&#xff0c; 就是每个地址都往里写0,0xffffffff&#xff0c;再写0x55…

【坑】idea终端下执行maven命令行报错:mvn clean install -Dspring.profiles.active=dev

直接看报错信息 解决方法 方法一 命令改为&#xff1a;mvn clean install -Dspring.profiles.activedev方法二 使用 cmd 进入命令行执行&#xff1a;mvn clean install -Dspring.profiles.activedev在新版本中的idea终端已经默认使用了类似windons10下的PowerShell窗口的风格…

『亚马逊云科技产品测评』活动征文|阿里云服务器亚马逊服务器综合评测

授权声明&#xff1a;本篇文章授权活动官方亚马逊云科技文章转发、改写权&#xff0c;包括不限于在 Developer Centre, 知乎&#xff0c;自媒体平台&#xff0c;第三方开发者媒体等亚马逊云科技官方渠道 文章目录 引言一、亚马逊&阿里云发展历史介绍1.1 亚马逊发展历史1.2…

【图像分类】【深度学习】【Pytorch版本】 GoogLeNet(InceptionV3)模型算法详解

【图像分类】【深度学习】【Pytorch版本】 GoogLeNet(InceptionV3)模型算法详解 文章目录 【图像分类】【深度学习】【Pytorch版本】 GoogLeNet(InceptionV3)模型算法详解前言GoogLeNet(InceptionV3)讲解Factorized Convolutions卷积分解InceptionV3结构ⅠInceptionV3结构ⅡInc…

CSGO游戏搬砖项目需要掌握哪些基础知识?

CSGO搬砖之90%饰品商人都不知道的玄学皮肤盘点 CSGO游戏搬砖主要就是倒卖装备&#xff0c;那具体是哪些装备&#xff0c;以及怎么去区分皮肤类型&#xff0c;今天童话就给大家介绍一下。 CSGO游戏搬砖虽然不要求会玩游戏&#xff0c;但是我们作为一个商人&#xff0c;要知道我…