LeetCode 1791. 找出星型图的中心节点(图的度数)

题意:
有一个无向的 星型 图,由 n 个编号从 1 到 n 的节点组成。
星型图有一个 中心 节点,并且恰有 n - 1 条边将中心节点与其他每个节点连接起来。

给你一个二维整数数组 edges ,其中 edges[i] = [ui, vi] 表示在节点 ui 和 vi 之间存在一条边。
请你找出并返回 edges 所表示星型图的中心节点。

数据范围:
3 <= n <= 1e5
edges.length == n - 1
edges[i].length == 2
1 <= ui, vi <= n
ui != vi
题目数据给出的 edges 表示一个有效的星型图
解法:
显然中心节点的度数最大,因此统计图中每个点的度数,度数最大的点就是答案.
code:
const int maxm=1e5+5;
int d[maxm];
class Solution {
public:
    int findCenter(vector<vector<int>>& e) {
        memset(d,0,sizeof d);
        int ma=0;
        int ans=-1;
        for(auto s:e){
            int ss=s[0],sss=s[1];
            d[ss]++;
            d[sss]++;
            if(d[ss]>ma){
                ma=d[ss];
                ans=ss;
            }
            if(d[sss]>ma){
                ma=d[sss];
                ans=sss;
            }
        }
        return ans;
    }
};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值