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

Posted 二当家的白帽子

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法leetcode每日一练1791. 找出星型图的中心节点相关的知识,希望对你有一定的参考价值。


文章目录


1791. 找出星型图的中心节点:

有一个无向的 星型 图,由 n 个编号从 1n 的节点组成。星型图有一个 中心 节点,并且恰有 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. 找出星型图的中心节点

「 每日一练,快乐水题 」1791. 找出星型图的中心节点

LeetCode Algorithm 1791. 找出星型图的中心节点

LeetCode 688. 骑士在棋盘上的概率 / 1791. 找出星型图的中心节点 / 969. 煎饼排序(冒泡排序)

算法61天|图论

算法leetcode每日一练2161. 根据给定数字划分数组