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

数据结构【树篇】(二)

数据结构【树篇】(二)


文章目录

  • 数据结构【树篇】(二)
  • 前言
    • 为什么突然想学算法了?
    • 为什么选择码蹄集作为刷题软件?
  • 目录
    • (一)、树的存储
    • (二)、树和森林的遍历——并查集
    • (三)、并查集的优化
  • 结语


前言

在这里插入图片描述

为什么突然想学算法了?

> 用较为“官方”的语言讲,是因为算法对计算机科学的所有分支都非常重要。 在绝大多数的计算机科学分支领域中,要想完成任何实质性的工作,理解算法的基础知识并掌握与算法密切相关的数据结构知识是必不可少的。
> 但从实际而言,是因为当下竞争压力逐渐增大,无论走哪一条路,都不免需要一些相对丰富的算法知识,是故,便产生了一个寒假巩固速成算法的计划,可能对于像我这种算法竞赛小白而言,几乎很难,但我仍然还是想尝试一下,毕竟,梦想还是要有的,万一实现了呢?~( ̄▽ ̄~)~

在这里插入图片描述


为什么选择码蹄集作为刷题软件?

码蹄集,是在全国高等学校计算机教学与产业实践资源建设专家委员会(TIPCC) 指导下建设的,其依托全国各大名校计算机系和清华大学出版社等单位的强大资源,旨在为计算机学习爱好者提供全面和权威的计算机习题。
.
在这里插入图片描述


目录

(一)、树的存储

.
参考代码

#define MAX_TREE_SIZE 100       //树中最多结点数//双亲表示法(顺序存储)
typedef struct{                 //树的结点定义int data;                   //数据元素int parent;                 //双亲位置域
}PTNode;typedef struct{                  //树的类型定义PTNode nodes[MAX_TREE_SIZE]; //双亲表示int n;                       //结点数
}PTree;//孩子表示法(顺序+链式存储)
struct CTNode{int child;                   //孩子结点在数组中的位置struct CTNode *next;         //下一个孩子
};
typedef struct {int data;struct CTNode *firstChild;   //第一个孩子
}CTBox;
typedef struct {CTBox nodes[MAX_TREE_SIZE];int n,r;                     //结点数和根的位置
}CTree;//孩子兄弟表示法(链式存储)
//树的存储——孩子兄弟表示法
typedef struct CSNode{int data;                               //数据域struct CSNode *firstchild,*nextsibling; //第一个孩子和右兄弟指针
}CSNode,*CSTree;

(二)、树和森林的遍历——并查集


#define SIZE 13
int UFSets[SIZE];               //集合元素数组//初始化并查集
void Initial(int S[]){for(int i=0;i<SIZE;i++)S[i]=-1;
}//Find "查"操作,找x所属集合(返回x所属根结点)
//最坏时间复杂度O(n)
int Find(int S[],int x){while(S[x]>0)               //循环寻找x的根x=S[x];return x;                   //根的S[]小于0
}//Union "并"操作,将两个集合合并为一个
//最坏时间复杂度O(1)
void Union (int S[],int Root1,int Root2){//要求Root1与Root2是不同的集合if(Root1==Root2) return;//将根据Root2连接到另一根Root1下面S[Root2]=Root1;
}

(三)、并查集的优化


//优化
void Union (int S[],int Root1,int Root2){if(Root1==Root2) return;if(S[Root2]>S[Root1]){          //Root2结点数更少S[Root1] += S[Root2];       //累加结点总数S[Root2]=Root1;             //小树合并到大树}else{S[Root2] += S[Root1];       //累加结点总数S[Root1]=Root2;             //小树合并到大树}S[Root2]=Root1;
}//Find "查"操作优化,先找到根节点,再进行“压缩路径”
int Find(int S[],int x){int root =x;while(S[root]>=0) root=S[root];     //循环找到根while(x!=root){                     //压缩路径int t=S[x];                     //t指向x的父节点S[x]=root;                      //x直接挂到根节点下x=t;}return root;                        //返回根节点编号
}

结语

感谢大家一直以来的不断支持与鼓励,码题集题库中的进阶塔350题正在逐步更新,之后会逐步跟进星耀,王者的题,尽请期待!!!
同时,也希望这些题能帮助到大家,一起进步,祝愿每一个算法道路上的“苦行僧”们,都能够历经磨难,终成正果,既然选择了这条路,走到了这里,中途放弃,岂不是太过可惜?

另附中国计算机学会的杰出会员、常务理事轩哥博士的B站视频讲解链接https://space.bilibili.com/518554541/?spm_id_from=333.999.0.0,供大家更好的进行学习与刷题~( ̄▽ ̄~)~

愿你的结局,配得上你一路的颠沛流离。
在这里插入图片描述

http://www.lryc.cn/news/273085.html

相关文章:

  • 2024上海城博会|上海国际城市与建筑博览会-官 网
  • Dockerfile - 基于 SpringBoot 项目自定义镜像(项目上线全过程)
  • 论文查重降重写成大白话可以吗
  • 【WPF.NET开发】WPF中的命令
  • 怎么将epub转换成txt文件?
  • Java单词排序
  • Moonsong Labs与Web3演变
  • 流媒体学习之路(WebRTC)——GCC分析(4)
  • k8s持久化存储(NFS-StorageClass)
  • java servlet软件缺陷库管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
  • 19|BabyAGI:根据气候变化自动制定鲜花存储策略
  • 面试经典150题(62-64)
  • 流量困境下,2024年餐饮商家的直播带货生意到底怎么做?
  • C++ 具名要求-基本概念-指定该类型对象可以默认构造
  • T527 Android13遥控适配
  • 第三部分使用脚手架:vue学习(61-65)
  • 【Linux学习笔记】解析Linux系统内核:架构、功能、工作原理和发展趋势
  • springboot连接oracle报错ORA-12505解决方案
  • 服务器为什么大多用 Linux?
  • C++上位软件通过Snap7开源库访问西门子S7-200/合信M226ES数据块的方法
  • 通信及信号处理领域期刊影响因子、分区及期刊推荐-2024版
  • cfa一级考生复习经验分享系列(十五)
  • 如潮好评!优秀选手视角下的第二届粤港澳大湾区(黄埔)国际算法算例大赛
  • 软件测试之冒烟测试
  • NE555学习笔记-2024
  • 记一次docker中安装redis的过程
  • Matlab进阶绘图第37期—多色悬浮柱状图
  • 【嵌入式】About USB Powering
  • MySQL——事物
  • Windows搭建RTSP视频流服务(EasyDarWin服务器版)