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

平面设计论坛seo案例分析100例

平面设计论坛,seo案例分析100例,php多用户商城双端app,苏州网站建设方案并查集里的 find 函数里可以进行路径压缩,是为了更快速的查找一个点的根节点。对于一个集合树来说,它的根节点下面可以依附着许多的节点,因此,我们可以尝试在 find 的过程中,从底向上,如果此时访问的节点不…

并查集里的 find 函数里可以进行路径压缩,是为了更快速的查找一个点的根节点。对于一个集合树来说,它的根节点下面可以依附着许多的节点,因此,我们可以尝试在 find 的过程中,从底向上,如果此时访问的节点不是根节点的话,那么我们可以把这个节点尽量的往上挪一挪,减少数的层数,这个过程就叫做路径压缩。

如下图中,find(4) 的过程就可以路径压缩,让数的层数更少。

节点 4 往上寻找根节点时,压缩第一步,树的层数就减少了一层:

节点 2 向上寻找,也不是根节点,那么把元素 2 指向原来父节点的父节点,操后后树的层数相应减少了一层,同时返回根节点 0。

find 过程代码修改为 :

// 查找过程, 查找元素p所对应的集合编号
// O(h)复杂度, h为树的高度
private int find(int p){assert( p >= 0 && p < count );// path compression 1while( p != parent[p] ){parent[p] = parent[parent[p]];p = parent[p];}return p;}

上述路径压缩并不是最优的方式,我们可以把最初的树压缩成下图所示,层数是最少的。

这个 find 过程代表表示为:

...
// 查找过程, 查找元素p所对应的集合编号
// O(h)复杂度, h为树的高度
private int find(int p) {assert (p >= 0 && p < count);//第二种路径压缩算法if (p != parent[p])parent[p] = find(parent[p]);return parent[p];
}
...

Java 实例代码

UnionFind3.java 文件代码:

package runoob.union;/*** 基于rank的优化*/
public class UnionFind4 {private int[] rank;   // rank[i]表示以i为根的集合所表示的树的层数private int[] parent; // parent[i]表示第i个元素所指向的父节点private int count;    // 数据个数// 构造函数public UnionFind4(int count){rank = new int[count];parent = new int[count];this.count = count;// 初始化, 每一个parent[i]指向自己, 表示每一个元素自己自成一个集合for( int i = 0 ; i < count ; i ++ ){parent[i] = i;rank[i] = 1;}}// 查找过程, 查找元素p所对应的集合编号// O(h)复杂度, h为树的高度private int find(int p){assert( p >= 0 && p < count );// 不断去查询自己的父亲节点, 直到到达根节点// 根节点的特点: parent[p] == pwhile( p != parent[p] )p = parent[p];return p;//第二种路径压缩算法//if( p != parent[p] )//parent[p] = find( parent[p] );//return parent[p];}// 查看元素p和元素q是否所属一个集合// O(h)复杂度, h为树的高度public boolean isConnected( int p , int q ){return find(p) == find(q);}// 合并元素p和元素q所属的集合// O(h)复杂度, h为树的高度public void unionElements(int p, int q){int pRoot = find(p);int qRoot = find(q);if( pRoot == qRoot )return;if( rank[pRoot] < rank[qRoot] ){parent[pRoot] = qRoot;}else if( rank[qRoot] < rank[pRoot]){parent[qRoot] = pRoot;}else{ // rank[pRoot] == rank[qRoot]parent[pRoot] = qRoot;rank[qRoot] += 1;   // 维护rank的值}}
}

http://www.tj-hxxt.cn/news/100456.html

相关文章:

  • java建设网站框架网站服务器速度对seo有什么影响
  • 网站备案可以更改吗酒店线上推广方案有哪些
  • 西安建网站公司哪家好互联网广告平台代理
  • 精通网站开发书籍关键词分析工具有哪些
  • 中国机械加工网官方网站企业官网定制设计
  • 成品网站5668入口的功能介绍最好用的搜索引擎排名
  • 商业网站怎么做培训网站建设
  • 临沂在线做网站营销型网站方案
  • linux主网站设计宁波企业seo服务
  • 做外贸找客户最好用的网站关键词排名关键词快速排名
  • 怎么用vs做网站网站建设推广
  • 建设部网站建筑工程质保期网站排名靠前方法
  • 设计欣赏网seo监控
  • 蚌埠市做家教网站百度一下官网首页百度一下
  • 建筑材料批发网站农产品网络营销
  • 专业的丹阳网站建设软文世界
  • 西峡网站建设2023疫情最新情况
  • 做网站的关键技术品牌传播推广方案
  • 网站建设和架构国内最新消息新闻
  • wordpress连接不了ftpseo每日工作内容
  • 北京做网站海宇勇创开发一个app平台大概需要多少钱?
  • 创建公司网站如何制作一个简易网站
  • 重庆五洲妇儿医院石家庄网络推广优化
  • 一般使用的分辨率的显示密度是多少dpi?关于进一步优化
  • 怎样做模板网站免费舆情监测平台
  • wap浏览器安卓版seo培训赚钱
  • 福建建设中心网站排行榜
  • 苏州网站建设公司山东关键词快速排名
  • 网站的建立过程关键词排名优化易下拉技巧
  • 微信网站的链接标志图片如何做镇江seo公司