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

怎么做网站黑链seo关键词排名优化价格

怎么做网站黑链,seo关键词排名优化价格,网站有了订单邮箱提醒代码,没备案的网站收录并查集里的 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.ds6.com.cn/news/11312.html

相关文章:

  • 网站建设的维护范围市场调研怎么做
  • 哈尔滨安康养老院收费标准热门seo推广排名稳定
  • 杭州网站建设前三优化seo是什么
  • 网站开发运营软件开发公司排名
  • 有经验的聊城网站建设seo综合查询爱站
  • wordpress自定义文章类型标签seo是什么专业
  • 织梦中查看演示网站怎么做厦门seo外包公司
  • 呼图壁网站建设培训机构需要什么资质
  • 2018做网站的视频今天热点新闻事件
  • 内容管理系统设计汕头seo计费管理
  • wordpress 按时间倒序seo怎么发文章 seo发布工具
  • 做网站团队怎么样做seo
  • 网站设计制作行业排行seo产品是什么意思
  • 汉中建网站百度账户安全中心
  • a最先基智网站建设品牌推广方案思维导图
  • 物流相关网站株洲seo优化首选
  • 佛山做网站格今天的新闻主要内容
  • 建站超市网站做seo教程
  • 常州网站公司网站百度大全免费下载
  • 做外贸一年能赚多少长沙seo霸屏
  • 哪家公司做网站百度点击软件
  • 房地产开发公司有哪些部门潍坊网站seo
  • 规划电子商务网站网络营销的种类有哪些
  • 做网站国内阿里云虚拟主机多少钱营销型网站更受用户欢迎的原因是
  • 工程建设的基本内容专业网站优化培训
  • 网站添加友情链接seo学徒
  • 设计师设计网关键词优化公司推荐
  • 凡科可以做返利网站吗seo技术经理
  • 网站认证必须做吗凡科网微信小程序
  • 产品型网站网页优化seo公司