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

长春网站建设b站在线观看人数在哪

长春网站建设,b站在线观看人数在哪,措美网站建设,公司怎么建网站做推广C语言实现并查集 导读一、并查集的定义1.1 定义解析二、逻辑结构三、存储结构3.1 树与森林的存储结构3.2 并查集的存储结构四、算法五、基本实现5.1 初始化5.2 查找5.3 合并5.4 算法测试六、算法分析6.1 时间复杂度6.2 空间复杂度结语导读 大家好,很高兴又和大家见面啦!!!…

C语言实现并查集

  • 导读
  • 一、并查集的定义
    • 1.1 定义解析
  • 二、逻辑结构
  • 三、存储结构
    • 3.1 树与森林的存储结构
    • 3.2 并查集的存储结构
  • 四、算法
  • 五、基本实现
    • 5.1 初始化
    • 5.2 查找
    • 5.3 合并
    • 5.4 算法测试
  • 六、算法分析
    • 6.1 时间复杂度
    • 6.2 空间复杂度
  • 结语

C语言实现并查集

导读

大家好,很高兴又和大家见面啦!!!

在上一篇内容中我们从数据结构的三要素初步认识了并查集这种数据结构,但是上一篇对并查集的介绍并不准确。

那我们对并查集的认识存在哪些错误呢?我们又应该如何实现并查集呢?在今天的内容中,我们将会从数据结构的三要素出发,进一步学习并实现并查集。

一、并查集的定义

并查集是一种高效管理不相交集合的数据结构,专门解决动态连通性问题。它通过树形结构组织集合元素,支持以下核心操作:

  • ​查询(Find)​:判断两个元素是否属于同一集合
  • ​合并(Union)​:将两个不相交的集合合并为一个集合

1.1 定义解析

并查集是一种高效管理不相交集合的数据结构

从第一句话的前部分中,我们需要提取3个关键信息:

  • 高效管理
  • 不相交集合
  • 数据结构

在上一篇内容中,我们认识了并查集是一种数据结构,其逻辑结构是集合,但是为什么说并查集是高效管理呢?

这是因为在实际的使用过程中,我们通过对并查集实现优化后能够做到近似常数级的时间复杂度。具体如何实现,后面我们会继续介绍,这里先不展开。

这里说的高效管理不相交集合实际上是指并查集中各个不相交的子集。

专门解决动态连通性问题

在第一句话的后半部分中,我们需要理解什么是动态连通性问题。

简单来说,就是查询两个元素是否连通,对两个不联通的元素建立连通关系。这也就是我们所说的查找与合并。

通过树形结构组织集合元素

这里所说的树形结构与传统的树形结构是有区别的:

  • 传统的树形结构就是我们前面学的递归结构,每一个结点都会通过其孩子指针指向孩子结点
  • 并查集中子集的树形结构并不属于递归结构,它是由每个结点的双亲指针指向该结点的父结点

树形结构

现在我们从定义出发,对并查集做出了一个更详细的介绍,下面我们继续来看一下并查集这种数据结构的三要素。

二、逻辑结构

并查集在逻辑上是由各棵不相交的子集组成的集合,子集中的元素在逻辑上呈现树形结构,每棵树的根结点作为子集的代表元素。

三、存储结构

在上一篇内容中,我们介绍了两种并查集的存储结构——顺序存储和链式存储。

但是上一篇的介绍是基于我们对并查集的初步理解而实现的,因此上一篇中提到的两种存储方式显然不能更加准确的表示并查集。

那对于并查集这个数据结构,我们又应该使用怎样的存储结构呢?下面我们就来分析一下;

3.1 树与森林的存储结构

在树与森林中,常用的存储结构有3种:

  • 双亲表示法:通过顺序存储实现,每个结点中存放结点数据信息与双亲位置信息;
//双亲表示法
typedef struct ParentNode {ElemType data;	// 数据域int parent;		// 双亲域
}PNode;//双亲结点
typedef struct Parent {PNode* list;//通过顺序表实现int n;//结点数量
}PTree;//双亲树
  • 孩子表示法:通过顺序表+链表实现,每个结点中存放结点数据与指向孩子链表的指针,孩子链表中存放孩子的位置信息;
//孩子表示法
typedef struct ChildNode {int pi;//孩子位置信息struct ChildNode* next_child;//孩子指针
}CNode;//孩子结点
typedef struct ParentNode {ElemType data;//结点数据域CNode* child;//孩子指针域
}PN;//双亲结点
typedef struct ChildTree 
http://www.dtcms.com/wzjs/466914.html

相关文章:

  • 营销的网站网站seo最新优化方法
  • 太原网站优化百度指数网址是什么
  • php做的卖水果网站西安网站建设排名
  • 旅游网站建设系统营销方式方案案例
  • 我想做服装网站怎么做收录平台
  • 有没有像一起做网店做男装的网站杭州关键词推广优化方案
  • 安徽网络营销企业服务aso优化师
  • 个人网站空间申请免费的拓客平台有哪些
  • 政府网站集约化平台建设工作方案网站文章优化技巧
  • 大连有几家做网站的公司天津seo优化排名
  • 自己做的网站怎么添加采集模块关键词优化seo费用
  • 惠州外包网站建设网站收录怎么做
  • 赤峰做网站开发百度竞价广告投放
  • 没有备案的网站 公司服务器 查到会怎么样b站不收费网站
  • 网站模板素材电商运营转行后悔了
  • 网站建设中字样图片今日头条新闻10条
  • 深度网网站建设方案电子商务seo实训总结
  • 海口网站建设 小黄网络百度联系电话
  • 拓者设计吧卧室效果图厦门seo全网营销
  • 网站建设86215山东最新资讯
  • 山东建设住建厅网站网络安全有名的培训学校
  • 做网站的格言搜狐新闻手机网
  • 日本 男女做受网站网站设计与网页制作
  • 邢台柏乡县建设局网站做网站公司
  • 网站月流量淘宝指数
  • 邯郸做移动网站价格营业推广是什么意思
  • 免费网站排名大全软文推广案例大全
  • 深圳做网站建设的哪家效果好又便宜推广什么app佣金高
  • 网站是什么东西下载谷歌浏览器
  • 大型手机网站制作百度seo最成功的优化