当前位置: 首页 > news >正文

C语言二叉树

1.思维导图

二叉树

 

2.将链式队列重新实现一遍

linkqueue.c

#include"linkqueue.h"
linkqueuePtr create()
{linkqueuePtr L=(linkqueuePtr)malloc(sizeof(linkqueue));if(NULL==L){printf("队列创建失败\n");return NULL;}L->head=(nodePtr)malloc(sizeof(node));if(NULL==L->head){printf("链式队列创建失败\n");free(L);L=NULL;return NULL;}L->head->len=0;L->head->next=NULL;L->tail=L->head;printf("链式队列创建成功\n");return L;
}int empty(linkqueuePtr L)
{if(NULL==L||L->head==NULL){printf("队列不合法\n");return -1;}return L->head==L->tail;
}void show(linkqueuePtr L)
{if(NULL==L||L->head==NULL||empty(L)){printf("遍历失败\n");return;}nodePtr q=L->head->next;while(q!=NULL){printf("%c ",q->data);q=q->next;}printf("\n");return;
}int push(linkqueuePtr L,DataType e)
{if(NULL==L||L->head==NULL){printf("队列不合法\n");return -1;}nodePtr n=(nodePtr)malloc(sizeof(node));if(NULL==n){printf("入队失败\n");return -2;}n->data=e;n->next=NULL;L->tail->next=n;L->tail=n;L->head->len++;show(L);return 0;
}int pop(linkqueuePtr L)
{if(NULL==L||L->head==NULL||empty(L)){printf("队列不合法\n");return -1;}nodePtr p=L->head->next;L->head->next=p->next;printf("%c出列\n",p->data);show(L);free(p);p=NULL;L->head->len--;if(L->head->next==NULL){L->tail=L->head;}return 0;
}int size(linkqueuePtr L)
{printf("队列大小为%d\n",L->head->len);show(L);return 0;
}void destroy(linkqueuePtr L)
{if(NULL==L){return;}if(NULL==L->head){free(L);L=NULL;}while(!empty(L)){pop(L);}free(L->head);free(L);L=NULL;printf("队列销毁成功\n");return;
}

 linkqueue.h

#ifndef LINKQUEUE_H
#define LINKQUEUE_H#include<stdio.h>
#include<stdlib.h>
#include<string.h>typedef char DataType;typedef struct node
{union{int len;DataType data;};struct node *next;
}node,*nodePtr;typedef struct LinkQueue
{nodePtr head;nodePtr tail;
}linkqueue,*linkqueuePtr;linkqueuePtr create();int empty(linkqueuePtr L);void show(linkqueuePtr L);int push(linkqueuePtr L,DataType e);int pop(linkqueuePtr L);int size(linkqueuePtr L);void destroy(linkqueuePtr L);#endif

main.c

#include"linkqueue.h"
int main()
{linkqueuePtr L=create();push(L,'a');push(L,'b');push(L,'c');push(L,'d');push(L,'e');pop(L);pop(L);pop(L);size(L);destroy(L);return 0;
}

输出结果:

3.将二叉树的创建和遍历重新实现一遍

tree.c

#include"tree.h"nodePtr tree_create()
{char value = 0;scanf("%c",&value);getchar();if(value=='#'){return NULL;}nodePtr n=(nodePtr)malloc(sizeof(node));if(NULL==n){printf("节点申请失败\n");return NULL;}n->data=value;n->L=tree_create();n->R=tree_create();return n;
}void pri_show(nodePtr T)
{if(NULL==T){return;}printf("%c ",T->data);pri_show(T->L);pri_show(T->R);
}void in_show(nodePtr T)
{if(NULL==T){return;}in_show(T->L);printf("%c ",T->data);in_show(T->R);
}void post_show(nodePtr T)
{if(NULL==T){return;}post_show(T->L);post_show(T->R);printf("%c ",T->data);
}

 tree.h

#ifndef TREE_H
#define TREE_H#include<stdio.h>
#include<stdlib.h>typedef int DataType;typedef struct node
{DataType data;struct node *L;struct node *R;
}node,*nodePtr;nodePtr tree_create();void pri_show(nodePtr T);void in_show(nodePtr T);void post_show(nodePtr T);#endif

main.c

#include"tree.h"
int main()
{nodePtr T=tree_create();if(NULL==T){return -1;}printf("二叉树创建成功\n");pri_show(T);printf("\n");return  0;
}

输出结果:

4.根据给出的二叉树序列画出该二叉树的图,并给出后序序列

前序遍历的顺序是: CABGHEDF

中序遍历的顺序是: GHBACDEF

5.

相关文章:

C语言二叉树

1.思维导图 树 二叉树 2.将链式队列重新实现一遍 linkqueue.c #include"linkqueue.h" linkqueuePtr create() {linkqueuePtr L(linkqueuePtr)malloc(sizeof(linkqueue));if(NULLL){printf("队列创建失败\n");return NULL;}L->head(nodePtr)malloc(si…...

智能工厂的设计软件 三种处理单元(NPU/GPU/CPU)及其在深度学习框架中的作用 之1

本文要点 深度学习&#xff1a;认知系统架构的处理层 在认知系统架构的设计和代码实现上 需要考虑多个层次&#xff0c;包括感知层、处理层、决策层和执行层。其中 深度学习主要用来解决处理层上的认知问题。 感知层&#xff1a;负责收集外部环境的信息。 处理层&#xff1a;…...

iOS swift开发系列--如何给swiftui内容视图添加背景图片显示

我需要在swiftui项目中显示背景图&#xff0c;有两种方式&#xff0c;一种是把图片拖入asset资源中&#xff0c;另外一种是直接把图片放在源码目录下。采用第一种方式&#xff0c;直接把图片拖到资源目录&#xff0c;但是swiftui项目没有弹出&#xff0c; “Copy items if need…...

jmeter后端监视器

一、概述 JMeter 后端监听器(Backend Listener)是 JMeter 提供的一个功能强大的插件,用于将测试执行期间收集的性能数据发送到外部系统进行监控和分析。通过后端监听器,您可以实时地将 JMeter 测试执行期间收集的数据发送到外部系统,如图形化展示、数据库、数据分析工具等…...

服务器数据恢复—RAIDZ离线硬盘数超过热备盘数导致阵列崩溃的数据恢复案例

服务器存储数据恢复环境&#xff1a; ZFS Storage 7320存储阵列中有32块硬盘。32块硬盘分为4组&#xff0c;每组8块硬盘&#xff0c;共组建了3组RAIDZ&#xff0c;每组raid都配置了热备盘。 服务器存储故障&#xff1a; 服务器存储运行过程中突然崩溃&#xff0c;排除人为误操…...

面试题整理4----lvs,nginx,haproxy区别和使用场景

LVS、Nginx、HAProxy&#xff1a;区别与使用场景 1. LVS&#xff08;Linux Virtual Server&#xff09;1.1 介绍1.2 特点1.3 使用场景 2. Nginx2.1 介绍2.2 特点2.3 使用场景 3. HAProxy3.1 介绍3.2 特点3.3 使用场景 4. 总结对比 在构建高可用、高性能的网络服务时&#xff0c…...

iOS - 超好用的隐私清单修复脚本(持续更新)

文章目录 前言开发环境项目地址下载安装隐私访问报告隐私清单模板最后 前言 在早些时候&#xff0c;提交应用到App Store审核&#xff0c;大家应该都收到过类似这样的邮件&#xff1a; Although submission for App Store review was successful, you may want to correct th…...

html <a>设置发送邮件链接、打电话链接 <a href=“mailto:></a> <a href=“tel:></a>

1.代码 <ul><li>电话&#xff1a;<a href"tel:18888888888">188-8888-8888</a></li><li>邮箱&#xff1a;<a href"mailto:10000qq.com">10000qq.com</a></li><li>邮箱&#xff1a;<a hre…...

clickhouse-副本和分片

1、副本 1.1、概述 集群是副本和分片的基础&#xff0c;它将ClickHouse的服务拓扑由单节点延伸到多个节点&#xff0c;但它并不像Hadoop生态的某些系统那样&#xff0c;要求所有节点组成一个单一的大集群。ClickHouse的集群配置非常灵活&#xff0c;用户既可以将所有节点组成…...

2009 ~ 2019 年 408【计算机网络】大题解析

2009 年 路由算法&#xff08;9’&#xff09; 讲解视频推荐&#xff1a;【BOK408真题讲解-2009年&#xff08;催更就退网版&#xff09;】 某网络拓扑如下图所示&#xff0c;路由器 R1 通过接口 E1 、E2 分别连接局域网 1 、局域网 2 &#xff0c;通过接口 L0 连接路由器 R2 &…...

vue2使用render,js中写html

1、js部分table.js export default {name: "dadeT",data() {return {dades: 6666};},render(h) {return h(div, [h(span, 组件数据&#xff1a;${this.dades}), // 利用data里的dades数据&#xff0c;展示在页面上h(span, 89855545)]);} };2、vue部分 <templat…...

如何有效划分服务器磁盘空间?具体的步骤和流程

有效划分服务器磁盘空间对于提升系统性能、管理方便性和数据安全性至关重要。合理的磁盘分区不仅有助于提高服务器的运行效率&#xff0c;还能在数据恢复、系统故障修复和存储管理方面提供更高的灵活性。以下是如何有效划分服务器磁盘空间的几个关键步骤和注意事项。 磁盘分区的…...

labelme标签批量转换数据集json_to_dataset

文章目录 labelme标签批量转换数据集json_to_dataset转换原理单张图片转换多张图片批量转换bat脚本循环法 标注图片提取标注图片转单通道 labelme标签批量转换数据集json_to_dataset 转自labelme批量制作数据集教程。 转换原理 在安装了labelme的虚拟环境中有一个labelme_js…...

Fisco-Bcos-java-SDK 利用java与fisco-Bcos区块链上的智能合约交互(以HelloWorld为例)

Fisco-Bcos-java-SDK 利用java与fisco-Bcos区块链上的智能合约交互&#xff08;以HelloWorld为例&#xff09; 一、部署智能合约 1、编写智能合约 此处用最简单的HelloWorld合约作为例子 包含两个方法和一个构造函数 构造函数&#xff1a;当合约部署的时候 执行构造函数 将…...

OpenHarmony-3.HDF Display子系统(6)

Display 子系统 1.Display驱动模型介绍 当前操作系统和 SOC 种类繁多&#xff0c;各厂商的显示屏器件也各有不同&#xff0c;随之针对器件的驱动代码也不尽相同&#xff0c;往往是某一款器件驱动&#xff0c;只适用于某单一内核系统或 SOC&#xff0c;如果要迁移到其他内核或者…...

Nginx中Server块配置的详细解析

Nginx中Server块配置的详细解析 一、Server块简介 在Nginx配置文件中&#xff0c;server块是非常关键的部分。它用于定义虚拟主机&#xff0c;一个server块就代表一个虚拟主机。这使得我们可以在一台Nginx服务器上通过不同的配置来处理多个域名或者基于不同端口的服务请求。 …...

php学习资料分享

php学习资料分享&#xff1a;夸克网盘分享...

EE308FZ_Sixth Assignment_Beta Sprint_Sprint Essay 3

Assignment 6Beta SprintCourseEE308FZ[A] — Software EngineeringClass Link2401_MU_SE_FZURequirementsTeamwork—Beta SprintTeam NameFZUGOObjectiveSprint Essay 3_Day5-Day6 (12.15-12.16)Other Reference1. WeChat Mini Program Design Guide 2. Javascript Style Guid…...

Eureka学习笔记-服务端

Eureka学习笔记 服务端 模块设计 Resources &#xff1a;这部分对外暴露了一系列的 Restful 接口。Eureka Client 的注册、心跳、获取服务列表等操作都需要调用这些接口。另外&#xff0c;其他的 Server 在同步 Registry 时也需要调用这些接口。Controller &#xff1a;这里提…...

无限次使用 cursor pro

github地址 cursor-vip 使用方式 在 MacOS/Linux 中&#xff0c;请打开终端&#xff1b; 在 Windows 中&#xff0c;请打开 Git Bash。 然后执行以下命令来安装&#xff1a; 部分电脑可能会误报毒&#xff0c;需要关闭杀毒软件/电脑管家/安全防护再进行 方式1&#xff1a;通过…...

凌壹科技ZO-3965U-6C2L嵌入式主板深度拆解:硬件解析与工业应用实战

1. 项目概述&#xff1a;一块嵌入式主板的深度拆解最近在整理手头的工控项目资料&#xff0c;翻出了一块来自凌壹科技的ZO-3965U-6C2L嵌入式主板。这块板子之前在一个边缘计算网关项目里服役了两年多&#xff0c;一直稳定可靠。趁着这个机会&#xff0c;我决定把它从机箱里拆出…...

深度解析AI模型Docker镜像:从DeepSeek部署到生产级容器化实践

1. 项目概述&#xff1a;一个AI模型镜像的深度解构最近在社区里看到不少朋友在讨论dirk1983/deepseek这个Docker镜像&#xff0c;作为一个长期在AI工程化和容器化部署一线摸爬滚打的从业者&#xff0c;我觉得有必要来聊聊这个看似简单的镜像背后&#xff0c;究竟藏着哪些门道。…...

数据结构第6章树和二叉树:课后习题全解析(选择题+填空题+综合题+算法设计题)

第6章 树和二叉树 课后习题一、单项选择题1. 一棵有 n 个结点&#xff0c;采用链式存储的二叉树中&#xff0c;共有&#xff08; A &#xff09;个指针域为空。A. n1 B. n C. n−1 D. n−2解析&#xff1a; 链式存储二叉树中&#xff0c;每个结点有 2 个指针域&#xff08;左孩…...

MoviePilot媒体元数据服务连接异常的技术诊断与系统解决方案

MoviePilot媒体元数据服务连接异常的技术诊断与系统解决方案 【免费下载链接】MoviePilot NAS媒体库自动化管理工具 项目地址: https://gitcode.com/gh_mirrors/mo/MoviePilot MoviePilot作为专业的NAS媒体库自动化管理工具&#xff0c;其核心功能依赖于TheMovieDb&…...

从“芯”出发:RK3588与树莓派5的硬件博弈与开发者抉择

1. 芯片架构的硬核对决 当RK3588遇上树莓派5&#xff0c;这场硬件较量就像两位武林高手过招。RK3588用的是台积电8nm工艺&#xff0c;四核Cortex-A76加四核Cortex-A55的big.LITTLE设计&#xff0c;主频最高2.4GHz。实测跑分时&#xff0c;A76大核单核性能比树莓派5的Cortex-A76…...

Zephyr 启动流程:从复位向量到main()的完整旅程

1. 从复位向量开始的奇妙旅程 当你按下嵌入式设备的电源按钮时&#xff0c;芯片内部就开始了一场精心编排的启动芭蕾。对于使用Zephyr RTOS的系统来说&#xff0c;这个旅程从复位向量&#xff08;Reset Vector&#xff09;开始&#xff0c;就像火车从始发站出发一样。Cortex-M架…...

基于代理建模与系统仿真的唐代政治制度数字重构

1. 项目概述与核心价值最近在开源社区里&#xff0c;我注意到一个名为“Tang-Political-System”的项目&#xff0c;它的名字直译过来是“唐代政治制度”。作为一个对历史、制度设计以及开源协作模式都抱有浓厚兴趣的开发者&#xff0c;这个项目立刻引起了我的注意。它并非一个…...

从零到一:基于STM32与MAX30102构建可穿戴健康监测原型

1. 硬件选型与原理分析 第一次接触MAX30102传感器时&#xff0c;我被它小巧的体积和强大的功能震撼到了。这个比指甲盖还小的芯片&#xff0c;居然能同时测量心率和血氧饱和度&#xff0c;这让我对可穿戴设备有了全新的认识。选择STM32F103作为主控&#xff0c;主要是看中它丰富…...

Crustocean/conch:轻量级容器化工具,简化开发者本地环境搭建

1. 项目概述&#xff1a;一个面向开发者的轻量级容器化工具最近在和一些做后端开发的朋友聊天&#xff0c;发现大家普遍有个痛点&#xff1a;本地开发环境和线上环境不一致&#xff0c;导致“在我机器上好好的”这种经典问题频繁上演。虽然Docker已经普及&#xff0c;但完整的D…...

OpenPnP贴片机新手避坑:从Allegro导出坐标文件到成功贴片,这5个细节决定成败

OpenPnP贴片机实战指南&#xff1a;从Allegro设计到精准贴片的5个关键控制点 引言 当PCB设计从图纸走向实体&#xff0c;贴片环节往往成为新手工程师的"滑铁卢"。我曾亲眼见证一个团队因为坐标文件导出时的0.5mm偏差&#xff0c;导致整批样板元件全部错位。这不是个例…...