有一个无向的 星型 图,由 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 <= 105edges.length == n - 1edges[i].length == 21 <= ui, vi <= nui != vi- 题目数据给出的
edges表示一个有效的星型图
代码:
class Solution {
public:
int findCenter(vector<vector<int>>& edges) {
int n = edges.size() + 1;
vector<int> Degres(n + 1);
for (auto& edge : edges) {
int u = edge[0];
int v = edge[1];
Degres[u]++;
Degres[v]++;
}
for (auto i = 1; i < n + 1; i++) {
if (Degres[i] == n - 1) {
return i;
}
}
return -1;
}
};
1164

被折叠的 条评论
为什么被折叠?



