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
本文要点 深度学习:认知系统架构的处理层 在认知系统架构的设计和代码实现上 需要考虑多个层次,包括感知层、处理层、决策层和执行层。其中 深度学习主要用来解决处理层上的认知问题。 感知层:负责收集外部环境的信息。 处理层:…...
iOS swift开发系列--如何给swiftui内容视图添加背景图片显示
我需要在swiftui项目中显示背景图,有两种方式,一种是把图片拖入asset资源中,另外一种是直接把图片放在源码目录下。采用第一种方式,直接把图片拖到资源目录,但是swiftui项目没有弹出, “Copy items if need…...
jmeter后端监视器
一、概述 JMeter 后端监听器(Backend Listener)是 JMeter 提供的一个功能强大的插件,用于将测试执行期间收集的性能数据发送到外部系统进行监控和分析。通过后端监听器,您可以实时地将 JMeter 测试执行期间收集的数据发送到外部系统,如图形化展示、数据库、数据分析工具等…...
服务器数据恢复—RAIDZ离线硬盘数超过热备盘数导致阵列崩溃的数据恢复案例
服务器存储数据恢复环境: ZFS Storage 7320存储阵列中有32块硬盘。32块硬盘分为4组,每组8块硬盘,共组建了3组RAIDZ,每组raid都配置了热备盘。 服务器存储故障: 服务器存储运行过程中突然崩溃,排除人为误操…...
面试题整理4----lvs,nginx,haproxy区别和使用场景
LVS、Nginx、HAProxy:区别与使用场景 1. LVS(Linux Virtual Server)1.1 介绍1.2 特点1.3 使用场景 2. Nginx2.1 介绍2.2 特点2.3 使用场景 3. HAProxy3.1 介绍3.2 特点3.3 使用场景 4. 总结对比 在构建高可用、高性能的网络服务时,…...
iOS - 超好用的隐私清单修复脚本(持续更新)
文章目录 前言开发环境项目地址下载安装隐私访问报告隐私清单模板最后 前言 在早些时候,提交应用到App Store审核,大家应该都收到过类似这样的邮件: 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>电话:<a href"tel:18888888888">188-8888-8888</a></li><li>邮箱:<a href"mailto:10000qq.com">10000qq.com</a></li><li>邮箱:<a hre…...
clickhouse-副本和分片
1、副本 1.1、概述 集群是副本和分片的基础,它将ClickHouse的服务拓扑由单节点延伸到多个节点,但它并不像Hadoop生态的某些系统那样,要求所有节点组成一个单一的大集群。ClickHouse的集群配置非常灵活,用户既可以将所有节点组成…...
2009 ~ 2019 年 408【计算机网络】大题解析
2009 年 路由算法(9’) 讲解视频推荐:【BOK408真题讲解-2009年(催更就退网版)】 某网络拓扑如下图所示,路由器 R1 通过接口 E1 、E2 分别连接局域网 1 、局域网 2 ,通过接口 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, 组件数据:${this.dades}), // 利用data里的dades数据,展示在页面上h(span, 89855545)]);} };2、vue部分 <templat…...
如何有效划分服务器磁盘空间?具体的步骤和流程
有效划分服务器磁盘空间对于提升系统性能、管理方便性和数据安全性至关重要。合理的磁盘分区不仅有助于提高服务器的运行效率,还能在数据恢复、系统故障修复和存储管理方面提供更高的灵活性。以下是如何有效划分服务器磁盘空间的几个关键步骤和注意事项。 磁盘分区的…...
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区块链上的智能合约交互(以HelloWorld为例) 一、部署智能合约 1、编写智能合约 此处用最简单的HelloWorld合约作为例子 包含两个方法和一个构造函数 构造函数:当合约部署的时候 执行构造函数 将…...
OpenHarmony-3.HDF Display子系统(6)
Display 子系统 1.Display驱动模型介绍 当前操作系统和 SOC 种类繁多,各厂商的显示屏器件也各有不同,随之针对器件的驱动代码也不尽相同,往往是某一款器件驱动,只适用于某单一内核系统或 SOC,如果要迁移到其他内核或者…...
Nginx中Server块配置的详细解析
Nginx中Server块配置的详细解析 一、Server块简介 在Nginx配置文件中,server块是非常关键的部分。它用于定义虚拟主机,一个server块就代表一个虚拟主机。这使得我们可以在一台Nginx服务器上通过不同的配置来处理多个域名或者基于不同端口的服务请求。 …...
php学习资料分享
php学习资料分享:夸克网盘分享...
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 :这部分对外暴露了一系列的 Restful 接口。Eureka Client 的注册、心跳、获取服务列表等操作都需要调用这些接口。另外,其他的 Server 在同步 Registry 时也需要调用这些接口。Controller :这里提…...
无限次使用 cursor pro
github地址 cursor-vip 使用方式 在 MacOS/Linux 中,请打开终端; 在 Windows 中,请打开 Git Bash。 然后执行以下命令来安装: 部分电脑可能会误报毒,需要关闭杀毒软件/电脑管家/安全防护再进行 方式1:通过…...
Llama-3.2V-11B-cot真实案例展示:OCR后图像逻辑推理生成可验证结论
Llama-3.2V-11B-cot真实案例展示:OCR后图像逻辑推理生成可验证结论 1. 模型能力概览 Llama-3.2V-11B-cot是一个突破性的视觉语言模型,它不仅能理解图像内容,还能进行系统性推理并生成可验证的结论。这个基于LLaVA-CoT论文实现的模型&#x…...
终极指南:深度解锁联想拯救者Y7000系列Insyde BIOS隐藏选项
终极指南:深度解锁联想拯救者Y7000系列Insyde BIOS隐藏选项 【免费下载链接】LEGION_Y7000Series_Insyde_Advanced_Settings_Tools 支持一键修改 Insyde BIOS 隐藏选项的小工具,例如关闭CFG LOCK、修改DVMT等等 项目地址: https://gitcode.com/gh_mirr…...
Gemini 3.1镜像实战:用三层思考架构与多模态引擎解决视频内容生产
谷歌2026年初发布的Gemini 3.1 Pro,凭借可配置的三层思考架构(低/中/高推理深度)和集成Veo视频引擎、Lyria 3音频引擎的多模态能力,为实际业务问题提供了全新的解决范式。国内开发者和内容创作者可通过聚合平台RskAi(w…...
Qwen3-14B私有化效果闭环:从部署→使用→反馈→迭代的完整链路
Qwen3-14B私有化效果闭环:从部署→使用→反馈→迭代的完整链路 1. 开箱即用的私有化部署方案 Qwen3-14B作为通义千问系列的最新大语言模型,在14B参数规模下展现出惊人的理解与生成能力。但对于企业用户而言,如何在自有环境中实现稳定、高效…...
nuScenes数据集避坑指南:从数据下载到多模态可视化完整流程
nuScenes数据集实战全解析:从环境搭建到多模态融合可视化 自动驾驶研究离不开高质量的数据集支持,而nuScenes作为目前最全面的多模态自动驾驶数据集之一,包含了丰富的传感器数据和精细的标注信息。但在实际使用过程中,从数据下载到…...
三三复制商业模式系统介绍
三三复制商业模式系统介绍:裂变逻辑与合规落地全解析在数字经济时代,社交电商与分销模式的创新成为企业突破增长瓶颈的关键。三三复制模式以其几何级数的裂变效率、清晰的层级收益结构和低门槛参与机制,在电商、直销等领域展现出强大的生命力…...
QMCDecode:让音乐自由播放的开源格式转换工具
QMCDecode:让音乐自由播放的开源格式转换工具 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac,qmc0,qmc3转mp3, mflac,mflac0等转flac),仅支持macOS,可自动识别到QQ音乐下载目录,默认转换结果存…...
如何高效使用Super IO插件:Blender批量导入导出终极指南
如何高效使用Super IO插件:Blender批量导入导出终极指南 【免费下载链接】super_io blender addon for copy paste import / export 项目地址: https://gitcode.com/gh_mirrors/su/super_io 想要在Blender中实现一键导入导出模型和图像吗?Super I…...
图片去水印 API 接口实战:网站如何实现自动去水印(Python / PHP / C#)
在做网站或后台系统时,一个很常见但容易被忽视的问题是: 👉 用户上传的图片自带水印 👉 平台展示希望统一成干净版本 👉 还要支持批量、自动化处理 👉 最好能无缝接入现有系统 如果你正在找: …...
OpCore-Simplify:从3天手动调试到3步智能配置,黑苹果配置的自动化革命
OpCore-Simplify:从3天手动调试到3步智能配置,黑苹果配置的自动化革命 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 想象一下…...


