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

做站用什么网站程序如何搭建个人网站

做站用什么网站程序,如何搭建个人网站,保定网站建设咨询,wordpress通知站点360搜索数据结构【树篇】(二) 文章目录 数据结构【树篇】(二)前言为什么突然想学算法了?为什么选择码蹄集作为刷题软件? 目录树(一)、树的存储(二)、树和森林的遍历——并查集(三)、并查集的优化 结语 前言 为什么突然想学算法了&#xf…

数据结构【树篇】(二)


文章目录

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


前言

在这里插入图片描述

为什么突然想学算法了?

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

在这里插入图片描述


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

码蹄集,是在全国高等学校计算机教学与产业实践资源建设专家委员会(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.ableceo.cn/news/88.html

相关文章:

  • bbs网站设计模板教育培训机构排名前十
  • 沈阳奇搜建站百度爱采购推广平台
  • 日本正能量不良网址直接进入汕头seo全网营销
  • 自己做本市网站seo外包公司兴田德润官方地址
  • 哪里可以做网赚网站广州网站设计制作
  • 马良行网站3d模型预览怎么做的磁力神器
  • 后台网站如何建设网络营销推广的目的
  • wordpress博客支出优化推广网站推荐
  • 成都网站建设找亮帅app定制开发
  • 自己做好网站seo百度排名优化
  • 如何建微信微商城网站西安seo诊断
  • 电商网站开发流程站长工具5g
  • 坑梓网站建设电视剧排行榜百度搜索风云榜
  • 用java做网站还是html广安seo外包
  • 日本真人做的视频网站金城武重庆森林经典台词
  • 华池网站建设互联网广告投放
  • 外贸企业 网站昆明网站seo公司
  • wordpress删除多余图片的插件搜索引擎网站优化推广
  • 怎么做推广赚钱搜索引擎外部链接优化
  • 做外汇都看那些网站长沙关键词优化方法
  • 怎么做盈利的网站ai智能营销系统
  • 最新章节 62.一起来做网站吧杭州网站排名提升
  • 淘宝客合伙人网站建设软文推广广告
  • 深圳罗湖企业网站建设报价厦门seo排名优化公司
  • vs中的网站导航怎么做常见的网络推广方式
  • 惠州做网站电话指数基金是什么意思
  • 做餐厅logo什么网站素材多企业网站建设的目的
  • 网站开发工程师好不好常见的关键词
  • 为外国企业做中文网站建设建设网站的网站首页
  • 苏州朗冠网站建设公司网络营销五个主要手段