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

leetcode684.冗余连接

 

 依旧是并查集问题,这道题目正好给定顶点数目和边的数目相等,只要找到其中的一条边删除将图转化为树就行,而这个多余的边起始就是并查集的添加过程中二者是同一个根(两个顶点早已经联通了),这时直接返回这条边就行

注意这题中的顶点编号从1开始,为保证一致性,father数组大小为n+1,0索引不使用

class Solution {
private:
    vector<int> father;

    void init() {
        for(int i=0;i<father.size();i++)
            father[i]=i;
    }

    int find(int v) {
        return v==father[v]?v:father[v]=find(father[v]);
    }

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

    bool join(int u,int v) {
        u=find(u);
        v=find(v);
        if(u==v)
            return false;
        else{
            father[v]=u;
            return true;
        }
    }
public:
    vector<int> findRedundantConnection(vector<vector<int>>& edges) {
        int n=edges.size();
        this->father=vector<int>(n+1);
        this->init();

        for(int i=0;i<n;i++){
            int u=edges[i][0];
            int v=edges[i][1];
            if(!this->join(u,v))
                return {u,v};
        }
        return {};
    }
};


http://www.kler.cn/a/596015.html

相关文章:

  • Python列表2
  • 单页响应式 图片懒加载HTML页面
  • 【资料分享】全志科技T113-i全国产(1.2GHz双核A7 RISC-V)工业核心板规格书
  • 【力扣/代码随想录】数组
  • 国产AI编程工具,助力3D“微”引擎开发!——从一场直播到工业科技需求的革新实践
  • idea 编译打包nacos2.0.3源码,生成可执行jar 包常见问题
  • W80x使用WM IoT SDK 2.X 开发(二)驱动tft屏幕
  • 自定义对象处理请求参数
  • MySQL 性能优化方向
  • vpc网络之间的关系
  • react学习1.搭建react环境
  • 常用的git和linux命令有哪些?
  • Linux开机、重启与用户登录注销全解析
  • STM32学习-Day5-中断
  • OpenCV vs MediaPipe:哪种方案更适合实时手势识别?
  • Vue3 在组件中判断事件是否注册
  • Linux 系统运行 Android 应用的几种方案
  • 【小派项目书】sprintboot + vue 语言实现
  • Jenkins Pipeline
  • Hugo 生成静态网站并部署到 GitHub Pages 的完整流程