news 2026/4/15 8:04:38

代码随想录 684.冗余连接

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
代码随想录 684.冗余连接

这道题也是并查集基础题目。

1.并查集可以解决的问题:

(1)判断两个节点是否在一个集合。

(2)将两个节点添加到一个集合中。

2.题目要求:对于一个无向图,返回一条可以删去的边,使得结果图是一个有着N个节点的树(即,只有一个根节点)。如果有多个答案,则返回二维数组中最后出现的边。

3.思路:可以从前向后遍历每一条边(因为优先让前面的边连上),边的两个节点如果不在同一个集合,就加入集合(即同一个根节点)。

(1)如下图所示,节点a和节点b不在同一个集合,那么就可以将两个节点连接在一起。

(2)如果边的两个节点已经出现在同一个集合里,则说明这条边的两个节点已经连在一起了,再加入这条边一定就出现环了,如下图所示。

4.注意:题目已说明该图是在树的基础上添加一条边得到,因此只会有一条冗余边,因此可以在遇到同一个根的两个节点后直接返回即可。

附代码:

class Solution { private int[] p; public int[] findRedundantConnection(int[][] edges) { int n = edges.length; p = new int[n]; for(int i = 0;i < n;i++){ p[i] = i; } for(int i = 0;;i++){ //无限循环,会一直执行到找到冗余边并返回,所以该方法一定有返回值(因为树的性质保证了该方法一定有一条冗余边) //若加上i < n条件,则编译器会认为如果循环内所有if(pa == pb)条件都不满足,那么循环会正常结束,此时循环结束后就没有返回值 //编译器在编译时只做静态代码分析,不执行程序逻辑推理 //编译器认为条件判断里的return只是可能返回,若加上i < n,有限循环中还需要在下面加一个return条件 int pa = find(edges[i][0] - 1); //因为节点编号从1开始,所以要 - 1做数组映射 int pb = find(edges[i][1] - 1); if(pa == pb){ return edges[i]; } p[pa] = pb; } } private int find(int x){ if(p[x] != x){ p[x] = find(p[x]); } return p[x]; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 3:19:02

汇编语言全接触-28.Win32调试API一

在本教程中,我们将学习Win32提供给开发者的用于调试的原语. 在教程的结尾,我们将学习如何调试一个进程. 下载 例子程序.理论:Win32有一些供程序员使用的API,它们提供相当于调试器的功能. 他们被称作Win32调试API(或原语).利用这些API,我们可以:加载一个程序或捆绑到一个正在运行…

作者头像 李华
网站建设 2026/4/13 17:48:05

nn.layernorm的认识

LayerNorm — PyTorch 2.9 documentation layernorm不是对通道进行归一化。而是对选定维度进行归一化。被选定的维度作为一个整体&#xff0c;计算出方差和均值然后进行对被选定维度进行归一化。 &#xff08;整体归一化的意思就是&#xff0c;如果把[C, H, W]作为归一化维度…

作者头像 李华
网站建设 2026/4/14 21:02:55

计算机网络体系结构核心知识点整理

计算机网络体系结构核心知识点整理 一、互联网的基本组成 互联网本质是“边缘部分核心部分”的分层结构&#xff0c;两者协同实现全球数据传输&#xff1a; 边缘部分 定义&#xff1a;所有连接到互联网的终端设备&#xff08;如个人电脑、手机、服务器&#xff09;&#xff0c;…

作者头像 李华
网站建设 2026/4/11 1:26:08

pythonstudy Day36

官方文档的阅读 疏锦行 import pandas as pd import numpy as npfrom sklearn.datasets import load_iris from sklearn.ensemble import RandomForestClassifierfrom pdpbox import pdp import matplotlib.pyplot as plt import plotly.io as pio pio.renderers.default &qu…

作者头像 李华
网站建设 2026/3/30 14:07:24

(23)声明Bean的注解

负责声明Bean的注解&#xff0c;常见的包括四个&#xff1a; ComponentControllerServiceRepository 源码如下&#xff1a; package com.powernode.annotation;import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.…

作者头像 李华