力扣-1791-找出新星图的中心节点

题目描述

有一个无向的 星型 图,由 n 个编号从 1 到 n 的节点组成。星型图有一个 中心 节点,并且恰有 n - 1 条边将中心节点与其他每个节点连接起来。

给你一个二维整数数组 edges ,其中 edges[i] = [ui, vi] 表示在节点 ui 和 vi 之间存在一条边。请你找出并返回 edges 所表示星型图的中心节点。

示例 1:

在这里插入图片描述

输入:edges = [[1,2],[2,3],[4,2]]
输出:2
解释:如上图所示,节点 2 与其他每个节点都相连,所以节点 2 是中心节点。
示例 2:
输入:edges = [[1,2],[5,1],[1,3],[1,4]]
输出:1
数据范围
3 <= n <= 105
edges.length == n - 1
edges[i].length == 2
1 <= ui, vi <= n
ui != vi
题目数据给出的 edges 表示一个有效的星型图
Java代码
答案1
class Solution {
    public int findCenter(int[][] edges) {
        int[] arr = new int[edges.length+2];
        for(int[] t : edges){
            arr[t[0]]++;
            arr[t[1]]++;
        }
        for(int i = 1;i  < arr.length;i++){
            if(arr[i] == edges.length) return i;
        }
        return -1;
    }
}
答案2
class Solution {
    public int findCenter(int[][] edges) {
        return (edges[0][0] == edges[1][0] || edges[0][0] == edges[1][1]) ? edges[0][0] :  edges[0][1];
    }
}
解题思路

这一题想要解题并不难,只要理解什么事星型图就行,不了解的各位可以百度一下,我没怎么做过图的题目,所以最开始也不了解,对题目还感到十分疑惑,为什么只给了边集不给节点数,于是第一次用hashset计算出节点数,然后再去计算各个节点的度,最后检查找出目标节点。后来了解到节点数就是边集数加一,于是有了答案一,最后看到官方题解提到两个边中出现的同一个,那么那个节点就是中心节点,于是写了答案二。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值