概述
文章目录
- 1791. 找出星型图的中心节点:
- 样例 1:
- 样例 2:
- 提示:
- 分析
- 题解
- java
- c
- c++
- python
- go
- rust
- javascript
- typescript
- 原题传送门:https://leetcode-cn.com/problems/find-center-of-star-graph/
1791. 找出星型图的中心节点:
有一个无向的 星型 图,由 n
个编号从 1
到 n
的节点组成。星型图有一个 中心 节点,并且恰有 n - 1
条边将中心节点与其他每个节点连接起来。
给你一个二维整数数组 edges
,其中 edges[i] = [
u
i
u_i
ui,
v
i
v_i
vi] 表示在节点
u
i
u_i
ui 和
v
i
v_i
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 <= 1 0 5 10^5 105
- edges.length == n - 1
- edges[i].length == 2
- 1 <= u i u_i ui, v i v_i vi <= n
- u i u_i ui != v i v_i vi
- 题目数据给出的 edges 表示一个有效的星型图
分析
- 面对这道算法题目,二当家的陷入了沉思。
- 如果理解题意,那么写出题解不难。
- 但是仔细思考一下就会发现,根本不需要遍历,除了中心节点,其他节点只会出现一次。
题解
java
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];
}
}
c
int findCenter(int** edges, int edgesSize, int* edgesColSize){
return edges[0][0] == edges[1][0] || edges[0][0] == edges[1][1] ? edges[0][0] : edges[0][1];
}
c++
class Solution {
public:
int findCenter(vector<vector<int>>& edges) {
return edges[0][0] == edges[1][0] || edges[0][0] == edges[1][1] ? edges[0][0] : edges[0][1];
}
};
python
class Solution:
def findCenter(self, edges: List[List[int]]) -> int:
return edges[0][0] if edges[0][0] == edges[1][0] or edges[0][0] == edges[1][1] else edges[0][1]
go
func findCenter(edges [][]int) int {
if edges[0][0] == edges[1][0] || edges[0][0] == edges[1][1] {
return edges[0][0]
}
return edges[0][1]
}
rust
impl Solution {
pub fn find_center(edges: Vec<Vec<i32>>) -> i32 {
if edges[0][0] == edges[1][0] || edges[0][0] == edges[1][1] {
edges[0][0]
} else {
edges[0][1]
}
}
}
javascript
/**
* @param {number[][]} edges
* @return {number}
*/
var findCenter = function(edges) {
return edges[0][0] === edges[1][0] || edges[0][0] === edges[1][1] ? edges[0][0] : edges[0][1];
};
typescript
function findCenter(edges: number[][]): number {
return edges[0][0] === edges[1][0] || edges[0][0] === edges[1][1] ? edges[0][0] : edges[0][1];
};
原题传送门:https://leetcode-cn.com/problems/find-center-of-star-graph/
非常感谢你阅读本文~
欢迎【????点赞】【⭐收藏】【????评论】~
放弃不难,但坚持一定很酷~
希望我们大家都能每天进步一点点~
本文由 二当家的白帽子:https://le-yi.blog.csdn.net/ 博客原创~
最后
以上就是尊敬外套为你收集整理的【算法leetcode每日一练】1791. 找出星型图的中心节点1791. 找出星型图的中心节点:样例 1:样例 2:提示:分析题解原题传送门:https://leetcode-cn.com/problems/find-center-of-star-graph/的全部内容,希望文章能够帮你解决【算法leetcode每日一练】1791. 找出星型图的中心节点1791. 找出星型图的中心节点:样例 1:样例 2:提示:分析题解原题传送门:https://leetcode-cn.com/problems/find-center-of-star-graph/所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复