[力扣题解] 1971. 寻找图中是否存在路径

题目:1971. 寻找图中是否存在路径

思路

并查集

代码

cpp 复制代码
class Solution {
private:
    int n = 200005;
    int father[200005] = {0};
    void init()
    {
        int i;
        for(i = 0; i < n; i++)
        {
            father[i] = i;
        }
    }

    int find(int u)
    {
        if(u == father[u])
        {
            return u;
        }
        else
        {
            return father[u] = find(father[u]);
        }
    }

    bool isSame(int u, int v)
    {
        u = find(u);
        v = find(v);
        return u == v;
    }

    // 加入 u -> v
    void join(int u, int v)
    {
        u = find(u);
        v = find(v);
        if(u == v)
        {
            return;
        }
        else
        {
            father[u] = v;
        }
    }


public:
    bool validPath(int n, vector<vector<int>>& edges, int source, int destination) {
        int i, u, v;
        init();
        for(i = 0; i < edges.size(); i++)
        {
            join(edges[i][0], edges[i][1]);
        }
        return isSame(source, destination);
    }
};

注意数组不要越界了,validPath函数里n是节点个数,edge长度是边的个数,可不一定相等哦!

相关推荐
XFF不秃头1 天前
【力扣刷题笔记-在排序数组中查找元素的第一个和最后一个位置】
c++·笔记·算法·leetcode
yoyo君~1 天前
FAST-LIVO2 深度技术解析
算法·计算机视觉·机器人·无人机
我也要当昏君1 天前
时间复杂度
算法·数学建模
业精于勤的牙1 天前
浅谈:算法中的斐波那契数(六)
人工智能·算法
小孟的CDN1 天前
使用pytorch进行batch_size分批训练,并使用adam+lbfgs算法——波士顿房价预测
pytorch·算法·batch·代码·adam+lbfgs
仰泳的熊猫1 天前
1037 Magic Coupon
数据结构·c++·算法·pat考试
AI科技星1 天前
质量定义方程的物理数学融合与求导验证
数据结构·人工智能·算法·机器学习·重构
小羊学伽瓦1 天前
ThreadLocal
java·jvm·算法
程芯带你刷C语言简单算法题1 天前
Day30~实现strcmp、strncmp、strchr、strpbrk
c语言·学习·算法·c
桓峰基因1 天前
SCS 60.单细胞空间转录组空间聚类(SPATA2)
人工智能·算法·机器学习·数据挖掘·聚类