一、 题目
1. 题目描述
有一个无向的 星型 图,由 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
表示一个有效的星型图
Related Topics
- 图
- 👍 58
- 👎 0
2. 原题链接
链接: 1791. 找出星型图的中心节点
二、 解题报告
1. 思路分析
水题,这里引入一个概念:每个节点有几个边,叫做这个节点的度
。
题中星型图中,除了中心点,其他点的度都是1。
找到度>=2的点即可。
2. 复杂度分析
因为每个边都会连着中心点,所以扫到第二条边就找到了。
复杂度O(1)
3.代码实现
水。
class Solution:
def findCenter(self, edges: List[List[int]]) -> int:
g = collections.defaultdict(list)
for u,v in edges:
g[u].append(v)
if len(g[u]) >= 2:
return u
g[v].append(u)
if len(g[v]) >= 2 :
return v
return -1
三、 本题小结
度
的概念