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

初识树(c语言)

定义:树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合。
有一个特殊的结点,称为根结点,根节点没有前驱结点
除根节点外,其余结点被分成M(M>0)个互不相交的集合T1T2……Tm,其中每一个集合Ti(1<= i <= m)又是一棵结构与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继结点
因此,树是递归定义的。
树形结构中,子树之间不能有交集,否则就不是树形结构

树的相关概念

节点的度 :一个节点含有的子树的个数称为该节点的度; 如上图: A 的为 6
叶节点或终端节点 :度为 0 的节点称为叶节点; 如上图: B C H I... 等节点为叶节点
非终端节点或分支节点 :度不为 0 的节点; 如上图: D E F G... 等节点为分支节点
双亲节点或父节点 :若一个节点含有子节点,则这个节点称为其子节点的父节点; 如上图: A B 的父节点
孩子节点或子节点 :一个节点含有的子树的根节点称为该节点的子节点; 如上图: B A 的孩子节点
兄弟节点 :具有相同父节点的节点互称为兄弟节点; 如上图: B C 是兄弟节点
树的度 :一棵树中,最大的节点的度称为树的度; 如上图:树的度为 6
节点的层次 :从根开始定义起,根为第 1 层,根的子节点为第 2 层,以此类推;
树的高度或深度 :树中节点的最大层次; 如上图:树的高度为 4
堂兄弟节点 :双亲在同一层的节点互为堂兄弟;如上图: H I 互为兄弟节点
节点的祖先 :从根到该节点所经分支上的所有节点;如上图: A 是所有节点的祖先
子孙 :以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是 A 的子孙
森林 :由 m m>0 )棵互不相交的树的集合称为森林;

树的表示

树结构相对线性表就比较复杂了,要存储表示起来就比较麻烦了, 既然保存值域,也要保存结点和结点之间 的关系 ,实际中树有很多种表示方式如:双亲表示法,孩子表示法、孩子双亲表示法以及孩子兄弟表示法等。我们这里就简单的了解其中最常用的孩子兄弟表示法
typedef int DataType;
struct Node
{
struct Node* _firstChild1; // 第一个孩子结点
struct Node* _pNextBrother; // 指向其下一个兄弟结点
DataType _data; // 结点中的数据域
};

相关文章:

初识树(c语言)

树 定义&#xff1a;树是一种非线性的数据结构&#xff0c;它是由n&#xff08;n>0&#xff09;个有限结点组成一个具有层次关系的集合。 有一个特殊的结点&#xff0c;称为根结点&#xff0c;根节点没有前驱结点 除根节点外&#xff0c;其余结点被分成M(M>0)个互不相交…...

听GPT 讲Rust源代码--src/librustdoc(2)

题图来自 Chromium项目将支持Rust编程语言[1] File: rust/src/librustdoc/html/render/search_index.rs 在Rust源代码中&#xff0c;rust/src/librustdoc/html/render/search_index.rs文件的作用是生成搜索索引&#xff0c;用于在Rust文档页面上进行关键字搜索。该文件实现了一…...

多目标应用:基于非支配排序的蜣螂优化算法NSDBO求解微电网多目标优化调度(MATLAB)

一、微网系统运行优化模型 微电网优化模型介绍&#xff1a; 微电网多目标优化调度模型简介_IT猿手的博客-CSDN博客 二、基于非支配排序的蜣螂优化算法NSDBO 基于非支配排序的蜣螂优化算法NSDBO简介&#xff1a; https://blog.csdn.net/weixin46204734/article/details/128…...

泉盛UV-K5/K6全功能中文固件

https://github.com/wu58430/uv-k5-firmware-chinese/releases 主要功能&#xff1a; 中文菜单 许多来自 OneOfEleven 的模块&#xff1a; AM 修复&#xff0c;显著提高接收质量长按按钮执行 F 操作的功能复制快速扫描菜单中的频道名称编辑频道名称 频率显示选项扫描列表分配…...

基于JPBC的无证书聚合签名方案实现

基于JPBC的无证书聚合签名方案实现 摘要 一开始签名方案是基于PKI的&#xff0c;无证书签名起源于 基于身份密码体制&#xff0c; 2009 年第一篇无证书签名方案1被提出&#xff0c;随后出现了一些列方案2,3;包括无配对的无证书聚合签名方案4,更多内容参考文献5. 暂时没有看见…...

FreeRTOS内存管理分析

目录 heap_1.c内存管理算法 heap_2.c内存管理算法 heap_3.c内存管理算法 heap_4.c内存管理算法 heap_5.c内存管理算法 内存管理对应用程序和操作系统来说非常重要&#xff0c;而内存对于嵌入式系统来说是寸土寸金的资源&#xff0c;FreeRTOS操作系统将内核与内存管理分开实…...

hashMap索引原理

平日里面经常使用map这种数据结构&#xff0c;令人称奇的是他的访问速度为什么那么快&#xff1f;为什么可以通过key以接近O(1)的速度查找&#xff1f; 一、基础数据结构特点分析 1.1数组 查找的时间复杂度为O(1) 插入时间复杂度为O(n) 1.2链表 查找的时间复杂度为O(n) 插…...

qcow2、raw、vmdk等镜像格式工具

如果没有qemu&#xff0c;可以从这里下载安装&#xff1a;https://qemu.weilnetz.de/w64/...

GaussDB新特性Ustore存储引擎介绍

1、 Ustore和Astore存储引擎介绍 Ustore存储引擎&#xff0c;又名In-place Update存储引擎&#xff08;原地更新&#xff09;&#xff0c;是openGauss 内核新增的一种存储模式。此前的版本使用的行存储引擎是Append Update&#xff08;追加更新&#xff09;模式。相比于Append…...

人工智能基础_机器学习046_OVR模型多分类器的使用_逻辑回归OVR建模与概率预测---人工智能工作笔记0086

首先我们来看一下什么是OVR分类.我们知道sigmoid函数可以用来进行二分类,那么多分类怎么实现呢?其中一个方法就是使用OVR进行把多分类转换成二分类进行计算. OVR,全称One-vs-Rest,是一种将多分类问题转化为多个二分类子问题的策略。在这种策略中,多分类问题被分解为若干个二…...

【LeetCode刷题-链表】--23.合并K个升序链表

23.合并K个升序链表 方法&#xff1a;顺序合并 在前面已经知道合并两个升序链表的前提下&#xff0c;用一个变量ans来维护以及合并的链表&#xff0c;第i次循环把第i个链表和ans合并&#xff0c;答案保存到ans中 /*** Definition for singly-linked list.* public class List…...

强化学习笔记

这里写自定义目录标题 参考资料基础知识16.3 有模型学习16.3.1 策略评估16.3.2 策略改进16.3.3 策略迭代16.3.3 值迭代 16.4 免模型学习16.4.1 蒙特卡罗强化学习16.4.2 时序差分学习Sarsa算法&#xff1a;同策略算法&#xff08;on-policy&#xff09;&#xff1a;行为策略是目…...

经典双指针算法试题(一)

&#x1f4d8;北尘_&#xff1a;个人主页 &#x1f30e;个人专栏:《Linux操作系统》《经典算法试题 》《C》 《数据结构与算法》 ☀️走在路上&#xff0c;不忘来时的初心 文章目录 一、移动零1、题目讲解2、讲解算法原理3、代码实现 二、复写零1、题目讲解2、讲解算法原理3、…...

MATLAB | 绘图复刻(十三) | 带NaN图例的地图绘制

有粉丝问我地图绘制如何添加NaN&#xff0c;大概像这样&#xff1a; 或者这样&#xff1a; 直接上干货&#xff1a; 原始绘图 假设我们有这样的一张图地图&#xff0c;注意运行本文代码需要去matlab官网下载Mapping Toolbox工具箱&#xff0c;但是其实原理都是相似的&…...

netty整合websocket(完美教程)

websocket的介绍&#xff1a; WebSocket是一种在网络通信中的协议&#xff0c;它是独立于HTTP协议的。该协议基于TCP/IP协议&#xff0c;可以提供双向通讯并保有状态。这意味着客户端和服务器可以进行实时响应&#xff0c;并且这种响应是双向的。WebSocket协议端口通常是80&am…...

选择PC示波器的10种理由!

PC示波器&#xff08;PCs&#xff09;在测试仪器领域中的关键项目上正迅速地取代传统的数字存储示波器&#xff08;DSOs&#xff09;&#xff0c;其中有十个理由&#xff1a; 小巧和便携示波器利用你的PC显示器实现大屏幕和精细彩色显示信号存储只受限于你的PC存储器大小捕捉波…...

【pytorch深度学习 应用篇02】训练中loss图的解读,训练中的问题与经验汇总

文章目录 loss图解析train loss ↘ \searrow ↘ ↗ \nearrow ↗ 先降后升 loss图解析 train loss ↘ \searrow ↘ 不断下降&#xff0c;test loss ↗ \nearrow ↗ 不断上升&#xff1a;原因很多&#xff0c;我是把workers1&#xff0c;batchSize8192train loss ↘ \searro…...

uniapp 微信小程序如何实现多个item列表的分享

以下代码是某个循环里面的item <button class"cu-btn" style"background-color: transparent;padding: 0;"open-type"share" :data-tree"item.treeId" :data-project"item.projectId"v-if"typeId1 && userI…...

.NET 8 正式 GA 遥遥领先

.NET 8 一正式 已正式 GA。 微软称 .NET 8 提供了数以千计的性能、稳定性和安全性改进&#xff0c;以及平台和工具增强功能&#xff0c;有助于提高开发者的工作效率和创新速度。 比如 .NET 8 为 Android 和 WASM 引入了全新的 AOT 模式、改进 System.Text.Json&#xff0c;以…...

2216. 美化数组的最少删除数 --力扣 --JAVA

题目 给你一个下标从 0 开始的整数数组 nums &#xff0c;如果满足下述条件&#xff0c;则认为数组 nums 是一个 美丽数组 &#xff1a; nums.length 为偶数对所有满足 i % 2 0 的下标 i &#xff0c;nums[i] ! nums[i 1] 均成立 注意&#xff0c;空数组同样认为是美丽数组。…...

Streamlit部署避坑指南:从本地localhost到公网可访问的完整流程(Heroku/Streamlit Cloud)

Streamlit部署避坑指南&#xff1a;从本地localhost到公网可访问的完整流程 当你兴奋地在本地运行起第一个Streamlit应用&#xff0c;看着localhost:8501上实时更新的数据可视化看板时&#xff0c;下一个自然的问题就是&#xff1a;如何让同事或客户也能访问这个工具&#xff1…...

力扣135分发糖果:代码随想录Day 29,掌握贪心算法的精髓

在算法学习过程中&#xff0c;力扣&#xff08;LeetCode&#xff09;的135题“分发糖果”是一个经典的题目&#xff0c;它考察了我们对于贪心算法的理解和运用。 这道题目源自实际应用场景&#xff0c;例如在团队绩效考核中&#xff0c;我们需要根据员工的表现来分配奖励。代码…...

基于MCP协议实现私有部署Azure DevOps与AI编程助手的安全集成

1. 项目概述&#xff1a;当本地开发遇上云端智能最近在折腾一个挺有意思的玩意儿&#xff0c;叫burcusipahioglu/azure-devops-mcp-onprem。乍一看这名字&#xff0c;又是 Azure DevOps&#xff0c;又是 MCP&#xff0c;还带个 on-prem&#xff0c;感觉有点绕。简单来说&#x…...

ART-PI开发板实测:解锁STM32H750隐藏的2MB Flash,手把手教你修改Keil MDK链接脚本

ART-PI开发板深度实战&#xff1a;解锁STM32H750隐藏Flash的完整工程指南 当ART-PI开发板遇上内存焦虑&#xff0c;开发者们往往在128KB的官方Flash限制下绞尽脑汁。但鲜为人知的是&#xff0c;STM32H750XBH6这颗芯片体内还沉睡着近16倍的存储潜力。本文将带你深入芯片内存架构…...

基于NeoGPT构建本地知识库:RAG技术实战与调优指南

1. 项目概述&#xff1a;当本地大模型遇上你的个人知识库最近在折腾本地大模型的朋友&#xff0c;可能都遇到过类似的困境&#xff1a;模型本身能力不差&#xff0c;但一聊到公司内部文档、个人笔记或者某个特定领域的专业资料&#xff0c;它就立刻“露怯”&#xff0c;要么胡说…...

模拟信号隔离技术:工业自动化中的地环路干扰解决方案

1. 模拟信号隔离的工业需求与技术痛点在工业自动化现场&#xff0c;我们经常遇到这样的场景&#xff1a;一台PLC需要采集分布在车间不同位置的传感器信号&#xff0c;这些传感器可能分别接在不同配电柜的电源上。当把这些信号直接接入采集系统时&#xff0c;显示器上会出现莫名…...

基于.NET 8与GPT的自动化博客写作工具:从原理到部署实践

1. 项目概述与核心价值 如果你和我一样&#xff0c;既想维护一个高质量的技术博客&#xff0c;又苦于没有足够的时间和精力去持续创作&#xff0c;那么今天分享的这个项目&#xff0c;绝对能让你眼前一亮。 calumjs/gpt-auto-blog-writer 是一个基于 .NET 8 开发的自动化博客…...

光纤传输技术在视频工程中的应用与选型指南

1. 光纤传输技术概述在广播电视和专业视频制作领域&#xff0c;光纤传输技术已经成为高质量视频信号传输的黄金标准。作为一名从业15年的视频系统工程师&#xff0c;我见证了这项技术如何彻底改变行业的面貌。记得2008年我第一次接触3G-SDI光纤传输系统时&#xff0c;那种震撼至…...

边缘与端点视频处理:SWaP-C权衡、内存优化与热设计实战

1. 项目概述&#xff1a;边缘与端点的实时视频SWaP-C权衡在嵌入式视觉和物联网领域&#xff0c;我们正处在一个数据爆炸的时代。摄像头无处不在&#xff0c;从智能手机到自动驾驶汽车&#xff0c;从工业检测到智能安防&#xff0c;它们每时每刻都在产生海量的视频流。作为一名长…...

解决SEGGER_RTT_printf无法打印浮点数问题

/* 在 SEGGER_RTT_vprintf 函数的 switch 语句中添加 */ case f: case F: {float fv (float)va_arg(*pParamList, double); // 注意&#xff1a;float 会提升为 doubleint integer (int)fv;int decimal;// 打印整数部分_PrintInt(&BufferDesc, integer, 10, 0, 0, 0);_S…...