栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【算法leetcode每日一练】1791. 找出星型图的中心节点

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【算法leetcode每日一练】1791. 找出星型图的中心节点


文章目录

1791. 找出星型图的中心节点:样例 1:样例 2:提示:分析题解

javacc++pythongorustjavascripttypescript 原题传送门: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 - 1edges[i].length == 21 <= 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>& 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>) -> i32 {
        if edges[0][0] == edges[1][0] || edges[0][0] == edges[1][1] {
            edges[0][0]
        } else {
            edges[0][1]
        }
    }
}

javascript
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/ 博客原创~


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/776965.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号