题目描述
有一个无向的 星型 图,由 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计算出节点数,然后再去计算各个节点的度,最后检查找出目标节点。后来了解到节点数就是边集数加一,于是有了答案一,最后看到官方题解提到两个边中出现的同一个,那么那个节点就是中心节点,于是写了答案二。