算法与数据结构(23)—— 并查集 路径压缩



在查找根节点,我们需要一个一个查找parent以得到这个集合的根节点。

那么我们在查找的时候,如果父节点不是根节点的话,可以指向父节点的父节点,这样就节省了不少树的高度(非递归版)。

  • 当然,因为节点是有指向父节点的,所以可以让每一个都指向根节点,根节点可以有无数个孩子(递归版)。
  • 理论上,递归版树的高度要低点,效率好,但是实际上,由于递归过程会产生额外的开销~

实际中,使用非递归的就可以了,面试的时候讲讲非递归的~


// 查找过程, 查找元素p所对应的集合编号
    // O(h)复杂度, h为树的高度
    private int find(int p){
        assert( p >= 0 && p < count );

        // path compression 1
        while( p != parent[p] ){
            parent[p] = parent[parent[p]];
            p = parent[p];
        }
        return p;

        // path compression 2, 递归算法
//            if( p != parent[p] )
//                parent[p] = find( parent[p] );
//            return parent[p];
    }


路径压缩中,不需要维护rank了吗?

    事实上,这就是把这个变量叫做rank而不叫height的原因。引入压缩路径,维护深度就变得困难了。

实际上,rank只是我们一个标志当前节点排名的一个数字,在压缩中,尽管rank高的点被抬上来了,但是每个集合的rank都相对的抬上来了,还是可以做一个参考的~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值