leetcode 2316.统计无向图中无法互相到达点对数

思路:并查集

其实就是连通块的一个变形题目,一般的连通块题目要我们求的是连通个数,或者能不能到达,这里反过来问了。

首先,我们用dfs也是可以做到的,在dfs中统计每一个连通块的个数,然后用乘法原理相乘,累计相加就得到结果了。

这里并查集思路差不多,只是用了并查集来找连通块而已。(这里并查集多了一个权值,用来统计每个并查集的点的个数)

注意:作者在统计多少对点到达不了的时候不会统计。这里看题解给出了思路,就是对于每一个连通块来说,连通块里面的点和另一个连通块里面的点是互不联通的,所以这里可以用乘法原理相乘,接着,我们再加入累加器当中,然后让点的个数合并成这两个连通块一共的点数,再让下一个连通块乘以这些点数,因为下一个连通块的每一点又与这两个连通块的每一个点都不相通,所以继续这样下去,累加,计数....

上代码:

class Solution {
public:
int f[100020];
int zhi[100020];
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=find(x);
    if(find(y)==s)
    return;
    else
    {
        zhi[find(y)]+=zhi[s];
        f[s]=find(y);
        
    }
}
    long long countPairs(int n, vector<vector<int>>& edges) {
        for(int i=0;i<n;i++){
            f[i]=i;
            zhi[i]=1;
        }
        for(int i=0;i<edges.size();i++){
            int x=edges[i][0];
            int y=edges[i][1];
            unit(x,y);
        }
        long long res=0;
        long long size=0;
        for(int i=0;i<n;i++){
            if(f[i]==i){
                res+=zhi[i]*size;//
                size+=zhi[i];//需要学习的地方
            }
        }
        return res;
    }
};

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-12 14:08:07       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-12 14:08:07       101 阅读
  3. 在Django里面运行非项目文件

    2024-05-12 14:08:07       82 阅读
  4. Python语言-面向对象

    2024-05-12 14:08:07       91 阅读

热门阅读

  1. 3.1 Gateway之路由请求和转发

    2024-05-12 14:08:07       31 阅读
  2. 理解并实现区块链智能合约

    2024-05-12 14:08:07       30 阅读
  3. 验证控件的学习

    2024-05-12 14:08:07       31 阅读
  4. 关于Windows驱动中DPC同步的一些见解说明

    2024-05-12 14:08:07       31 阅读
  5. 页面静态化

    2024-05-12 14:08:07       33 阅读
  6. C#识别图片数字

    2024-05-12 14:08:07       23 阅读
  7. C++的数据结构(一)

    2024-05-12 14:08:07       28 阅读
  8. 【视频/图像数据格式】基本视频/图像数据格式

    2024-05-12 14:08:07       24 阅读
  9. 了解WebSocket

    2024-05-12 14:08:07       34 阅读
  10. MapReduce

    MapReduce

    2024-05-12 14:08:07      36 阅读