【数据结构】二叉链表创建二叉树(C语言版)

数据结构——二叉链表创建二叉树
  • 一、思想(先序思想创建):
  • 二、创建二叉树
    • (1)传一级参数方法
    • (2)传二级参数方法

一、思想(先序思想创建):

第一步先创建根节点,然后创建根节点左子树,开始递归创建左子树,直到递归创建到的节点下不继续创建左子树,也就是当下递归到的节点下的左子树指向NULL,结束本次左子树递归,返回这个节点的上一个节点,开始创建右子树,然后又开始以当下这个节点,继续递归创建左子树,左子树递归创建完,就递归创建右子树,直到递归结束返回到上一级指针节点(也就是根节点下),此时根节点左边子树创建完毕,开始创建右边子树,原理和根节点左边创建左右子树相同

二、创建二叉树

二叉树的操作通常使用递归方法,如果递归不太明白,建议去对此进行一下学习和练习。二叉树的操作可以分为两类,一类是需要改变二叉树的结构的,比如二叉树的创建、节点删除等等,这类操作,传入的二叉树的节点参数为二叉树指针的地址,这种参入传入,便于更改二叉树结构体的指针(即地址)。这里稍微有一点点绕,可能需要多思考一下

  • 如下是二叉数创建的函数,这里我规定,节点值为整数,如果输入的数为-1,则表示结束继续往下创建子节点的操作。然后我们使用递归的方法以此创建左子树和右子树

二叉树结构体初始化

为了更方便的使用二叉树结构体,可以使用 typedef 对结构体进行命名

typedef struct Tree{int data;					//	存放数据域struct Tree *lchild;			//	遍历左子树指针struct Tree *rchild;			//	遍历右子树指针}Tree,*BitTree;

这里展示两种传参类型的创建方法,其中深意可多次参考理解,加深指针理解

(1)传一级参数方法

BitTree CreateLink()
{int data;int temp;BitTree T;scanf("%d",&data);		//	输入数据temp=getchar();			//	吸收空格if(data == -1){			//	输入-1 代表此节点下子树不存数据,也就是不继续递归创建return NULL;}else{T = (BitTree)malloc(sizeof(Tree));			//		分配内存空间T->data = data;								//		把当前输入的数据存入当前节点指针的数据域中printf("请输入%d的左子树: ",data);		T->lchild = CreateLink();					//		开始递归创建左子树printf("请输入%d的右子树: ",data);			T->rchild = CreateLink();					//		开始到上一级节点的右边递归创建左右子树return T;							//		返回根节点}	}

(2)传二级参数方法

BitTree CreateLink(BitTree *T)		//	次数 T为指向根节点的指针的地址
{int data;	scanf("%d",&data);if(data == -1){*T=NULL;				//	结束递归时,让指针当前节点的指针地址的 指针 指向NULL}else{*T = (BitTree)malloc(sizeof(Tree));		//	对指向节点指针地址的指针 分配内存if(!(*T) ){			//	*T = NULL  表示分配内存失败,也就是结束递归创建了printf("内存分配失败\n");exit(-1);}(*T)->data = data;		//	给节点指针地址内的数据域,存入数据printf("请输入%d的左子树: ",data);CreateLink(&(*T)->lchild);		//	开始遍历左子树printf("请输入%d的右子树: ",data);CreateLink(&(*T)->rchild);		//	开始遍历右子树,遍历的思想文章开头处解释}
}

(1)一级参数完整例子:

#include<stdio.h>
#include<stdlib.h>typedef struct Tree{int data;					//	存放数据域struct Tree *lchild;			//	遍历左子树指针struct Tree *rchild;			//	遍历右子树指针}Tree,*BitTree;BitTree CreateLink()
{int data;int temp;BitTree T;scanf("%d",&data);		//	输入数据temp=getchar();			//	吸收空格if(data == -1){			//	输入-1 代表此节点下子树不存数据,也就是不继续递归创建return NULL;}else{T = (BitTree)malloc(sizeof(Tree));			//		分配内存空间T->data = data;								//		把当前输入的数据存入当前节点指针的数据域中printf("请输入%d的左子树: ",data);		T->lchild = CreateLink();					//		开始递归创建左子树printf("请输入%d的右子树: ",data);			T->rchild = CreateLink();					//		开始到上一级节点的右边递归创建左右子树return T;							//		返回根节点}		
}void ShowXianXu(BitTree T)			//		先序遍历二叉树
{if(T==NULL){return;}printf("%d ",T->data);ShowXianXu(T->lchild);			//	递归遍历左子树ShowXianXu(T->rchild);			//	递归遍历右子树
}int main()
{BitTree S;printf("请输入第一个节点的数据:\n");S = CreateLink();			//		接受创建二叉树完成的根节点ShowXianXu(S);				//		先序遍历二叉树return 0;	
} 

(2)二级参数完整例子

#include<stdio.h>
#include<stdlib.h>
typedef struct Tree{int data;struct Tree *lchild;struct Tree *rchild;
}Tree,*BitTree;BitTree CreateLink(BitTree *T)		//	次数 T为指向根节点的指针的地址
{int data;	scanf("%d",&data);if(data == -1){*T=NULL;				//	结束递归时,让指针当前节点的指针地址的 指针 指向NULL}else{*T = (BitTree)malloc(sizeof(Tree));		//	对指向节点指针地址的指针 分配内存if(!(*T) ){			//	*T = NULL  表示分配内存失败,也就是结束递归创建了printf("内存分配失败\n");exit(-1);}(*T)->data = data;		//	给节点指针地址内的数据域,存入数据printf("请输入%d的左子树: ",data);CreateLink(&(*T)->lchild);		//	开始遍历左子树printf("请输入%d的右子树: ",data);CreateLink(&(*T)->rchild);		//	开始遍历右子树,遍历的思想文章开头处解释}	}void ShowXianXu(BitTree T)		//	先序遍历二叉树
{if(T==NULL){return;}printf("%d ",T->data);ShowXianXu(T->lchild);		//	遍历左子树ShowXianXu(T->rchild);		//	遍历右子树
}int main()
{BitTree *S;			//	创建指向这个结构体指针地址 的指针printf("请输入第一个节点的数据:\n");CreateLink(&S);		//	传二级指针地址ShowXianXu(S);		return 0;	
} 

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

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

相关文章

深度解析Pandas聚合操作:案例演示、高级应用与实战技巧【第74篇—Pandas聚合】

深度解析Pandas聚合操作&#xff1a;案例演示、高级应用与实战技巧 在数据分析和处理领域&#xff0c;Pandas一直是Python中最受欢迎的库之一。它提供了丰富的数据结构和强大的功能&#xff0c;使得数据清洗、转换和分析变得更加高效。其中&#xff0c;Pandas的聚合操作在数据…

数据库基础学习笔记

一.基础概念 数据库、数据库管理系统、SQL 主流数据库&#xff1a; mysql的安装&#xff1a;略 mysql图形化界面的安装&#xff1a;略 二.数据模型 1). 关系型数据库&#xff08;RDBMS&#xff09; 概念&#xff1a;建立在关系模型基础上&#xff0c;由多张相互连接的二维表…

C++局部变量与全局变量

在C中&#xff0c;可以为函数的参数指定默认值。这样做的好处是在调用函数时&#xff0c;如果没有提供对应的参数&#xff0c;那么将会使用默认值。 下面是一个求2个或3个数中最大数的函数的示例&#xff0c;其中使用了默认参数&#xff1a; #include <iostream> using…

华为 huawei 交换机 接口 MAC 地址学习限制接入用户数量 配置示例

目录 组网需求: 配置思路&#xff1a; 操作步骤&#xff1a; 配置文件&#xff1a; 组网需求: 如 图 2-14 所示&#xff0c;用户网络 1 和用户网络 2 通过 LSW 与 Switch 相连&#xff0c; Switch 连接 LSW 的接口为GE0/0/1 。用户网络 1 和用户网络 2 分别属于 VLAN10 和 V…

金融行业新一代安防集中系统建设实践

文章目录 前言一、安全生产面临新挑战,新一代安防系统亟待筹建二、建设目标:围绕安防数字化、智能化,全面打造新一代安防集中系统平台三、搭建企业级安防系统应用架构四、模块化设计,实现安全管理、安全操作流程全覆盖五、首次基于实际应用的创新点(一)创新点:实现统一协…

OutputSteam.nullOutputStream()和InputStream.nullInputStream()有什么用

OutputSteam.nullOutputStream()有什么用 答案来自ChatGPT。 OutputStream.nullOutputStream 是 Java 中的一个特殊输出流对象&#xff0c;它被设计用于将所有写入操作都静默地丢弃&#xff0c;即不进行任何实际输出&#xff0c;也不引发异常。这个输出流通常用于一些情况下&…

导数的定义【高数笔记】

【含义】可以抽象成&#xff0c;在一个极其短的时间段内&#xff0c;温度差 / 时间差 【本质】瞬间的平均值 【分类】可以分成几类&#xff1f;每类需要注意的点 【导数存在的必要条件】 【导数与极限的关系】可以参考导数的定义的式子 【题型解法】分几个题型&#xff1f;每个…

基于微信小程序的校园故障维修管理系统的研究与实现

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

电路设计(16)——纪念馆游客进出自动计数显示器proteus仿真

1.设计要求 设计、制作一个纪念馆游客进出自动计数显示器。 某县&#xff0c;有一个免费参观的“陶渊明故里纪念馆”&#xff0c;游客进出分道而行&#xff0c;如同地铁有确保单向通行的措施。在入口与出口处分别设有红外检测、声响、累加计数器装置&#xff0c;当游人进&#…

python:xml.etree,用 xmltodict 转换为json数据,生成jstree所需的文件

请参阅&#xff1a;java : pdfbox 读取 PDF文件内书签 或者 python&#xff1a;从PDF中提取目录 请注意&#xff1a;书的目录.txt 编码&#xff1a;UTF-8&#xff0c;推荐用 Notepad 转换编码。 xml 是 python 标准库&#xff0c;在 D:\Python39\Lib\xml\etree pip install …

LeetCode 144 二叉树的前序遍历

大家新年快乐&#xff0c;long年大吉 今天的题很简单&#xff0c;前序用栈就行。 电脑没拿&#xff0c;用我妈的pad艰难敲代码&#xff0c;敲字 知识点随便写点吧&#xff0c;这里基础点挺多&#xff0c;以后补充下 栈&#xff1a;先进后出&#xff0c;数据结构用stack&…

c++中的模板(3) -- 函数模板和函数重载

目录 分析: 函数模板重载 分析: 前面说到&#xff0c;模板的存在可以替换所有的类型&#xff0c;那么如果我们写了函数模板之后&#xff0c;还能否写(同名)具体类型的函数了? 并且在写了之后&#xff0c;如果我们调用这个函数是调用函数模板还是具体的函数? /*函数模…

【北邮鲁鹏老师计算机视觉课程笔记】04 fitting 拟合

【北邮鲁鹏老师计算机视觉课程笔记】04 fitting 拟合 1 拟合的任务 如何从边缘找出真正的线&#xff1f; 存在问题 ①噪声 ②外点、离群点 ③缺失数据 2 最小二乘 存在的问题 3 全最小二乘 度量的是点到直线的距离而不是点在y方向到直线的距离 提示&#xff1a;点到直线的…

git的操作(Operation of Git)

下载git&#xff0c;以archlinux为例&#xff1a;yay -S git git分为三个区 暂存区&#xff1a;工作区的变更提交到暂存区 工作区&#xff1a;存放文件的地方 版本库&#xff1a;暂存区的内容提交到版本库 # 新建 # 在当前目录初始化git代码库 git init # 将指定目录新建并…

Golang开发:跨域配置

跨域中间件 /lib/middleware/crossorigin_mv.go package middlewareimport ("github.com/gin-gonic/gin""net/http" )/*** 跨域设置*/ func CrossOriginMiddleware() gin.HandlerFunc {return func(context *gin.Context) {method : context.Request.Met…

Educational Codeforces Round 135 (Rated for Div. 2)C. Digital Logarithm(思维)

文章目录 题目链接题意题解代码 题目链接 C. Digital Logarithm 题意 给两个长度位 n n n的数组 a a a、 b b b&#xff0c;一个操作 f f f 定义操作 f f f为&#xff0c; a [ i ] f ( a [ i ] ) a [ i ] a[i]f(a[i])a[i] a[i]f(a[i])a[i]的位数 求最少多少次操作可以使 …

操作系统基础:IO核心子系统【下】

&#x1f308;个人主页&#xff1a;godspeed_lucip &#x1f525; 系列专栏&#xff1a;OS从基础到进阶 &#x1f3c6;&#x1f3c6;本文完整PDF源文件请翻阅至文章底部下载。&#x1f3c6;&#x1f3c6; ⚕️1 I/O核心子系统——概述&#x1f531;1.1 核心子系统要完成的功能…

视觉SLAM十四讲学习笔记(二)三维空间刚体

哔哩哔哩课程连接&#xff1a;视觉SLAM十四讲ch3_哔哩哔哩_bilibili​ 目录 一、旋转矩阵 1 点、向量、坐标系 2 坐标系间的欧氏变换 3 变换矩阵与齐次坐标 二、实践&#xff1a;Eigen&#xff08;1&#xff09; 运行报错记录与解决 三、旋转向量和欧拉角 1 旋转向量 …

速盾:怎么拿高防服务器做CDN

想要拿高防服务器做CDN&#xff0c;首先需要了解什么是CDN。CDN&#xff0c;即内容分发网络&#xff08;Content Delivery Network&#xff09;&#xff0c;是一种通过互联网连接多个服务器&#xff0c;将静态和动态内容分发到最接近用户的服务器节点&#xff0c;从而提高用户访…

备份还原实际操作

备份还原实际操作 前言 根据达梦文档整理。 一、工具介绍 工具联机/脱机工具应用场景disql联机1️⃣数据库备份2️⃣归档备份3️⃣表空间备份与还原4️⃣表备份与还原dmrman脱机1️⃣数据库备份、还原和恢复2️⃣脱机还原表空间3️⃣归档的备份、还原和修复manager联机对应…