leetcode 684.冗余连接

思路:并查集

这里的图比较像一种特殊的数据结构,其实也是图论的一种东西,就是基环树,但是这里并不是有向图,而是无向图,所以并不能用那种剪枝操作然后找基环。

看到连通量,我们应该能想到两种方法:一种就是DFS,BFS这样的搜索来判断连通,还有一种就是数据结构里面的一种:并查集。

这两种方法在求连通分块的时候其实各有千秋,并查集比较快,但是有时候处理起来很麻烦;DFS这种搜索反而是比较常用的。这里作者作了一点小总结:

涉及到点的遍历一类的连通量,用DFS这样的搜索比较方便;但是涉及到边的问题的时候,其实用并查集很有用。就好像加点法和加边法求最小生成树那样。

这里用到并查集其实就看到连通量里面有多余的边,而并查集恰好能够通过不断合并的过程判断是不是多余了。

复制代码
class Solution {
public:
int f[1100];
int find(int u){
    if(f[u]==u)
    return u;
    else
    return f[u]=find(f[u]);
}
void unit(int x,int y){
    int s=f[x];
    if(s==f[y])
    return ;
    else
    f[s]=f[y];
}
    vector<int> findRedundantConnection(vector<vector<int>>& edges) {
        int n=edges.size();
        for(int i=1;i<=n;i++){
            f[i]=i;
        }
        vector<int>res;
        for(int i=0;i<n;i++){
            int x=edges[i][0];
            int y=edges[i][1];
            if(find(x)!=find(y)){
                unit(x,y);
            }
            else{
                res.push_back(x);
                res.push_back(y);
                break;
            }
        }
        return res;
    }
};
相关推荐
多则惑少则明4 小时前
java 代码查重(三)常见的距离算法和相似度(相关系数)计算方法
java·算法·常见的距离算法和相似度
项目申报小狂人4 小时前
高性能算法RIME:基于物理的优化的霜冰优化算法
算法
水蓝烟雨5 小时前
[每日一题] 3362. 零数组变换 iii
算法·每日一题
项目申报小狂人5 小时前
完整改进RIME算法,基于修正多项式微分学习算子Rime-ice增长优化器,完整MATLAB代码获取
学习·算法·matlab
Cherl.5 小时前
探索数据结构的时间与空间复杂度:编程世界的效率密码
c语言·数据结构·算法·时间复杂度·空间复杂度
Yu_Mao_Cat5 小时前
数独求解器3.0 增加latex格式读取
开发语言·python·算法
爱coding的橙子6 小时前
每日算法刷题计划day13 5.22:leetcode不定长滑动窗口最短/最小1道题+求子数组个数越长越合法2道题,用时1h
算法·leetcode·职场和发展
编程绿豆侠6 小时前
力扣HOT100之二叉树: 437. 路径总和 III
算法·leetcode·哈希算法
范纹杉想快点毕业7 小时前
Google C++ Style Guide 谷歌 C++编码风格指南,深入理解华为与谷歌的编程规范——C和C++实践指南
c语言·数据结构·c++·qt·算法
烨然若神人~7 小时前
算法第26天 | 贪心算法、455.分发饼干、376. 摆动序列、 53. 最大子序和
算法·贪心算法