leetcode-1334

题意分析

1334. 阈值距离内邻居最少的城市 - 力扣(LeetCode)

        就是求给定一点,到其他点最短距离小于某个给定值,它的邻居数量。输出邻居数量最少的点。

算法思路

        看到任意2点的最短路,很直接可以想到floyd算法。floyd算法不难理解而且实现非常简单(下图),就是不断枚举插入新节点,看是不是可以使两点间路径更短。这可以算是经典题了。

        vector<vector<int>> dist(n,vector<int>(n,inf));
        for(int k=0;k<n;k++){
            for(int u=0;u<n;u++){
                for(int v=0;v<n;v++){
                    dist[u][v]=min(dist[u][v],dist[u][k]+dist[k][v]);
                }
            }
        }

代码实现

class Solution {
public:
    int findTheCity(int n, vector<vector<int>>& edges, int distanceThreshold) {
        const int inf=INT_MAX/2;
        vector<vector<int>> dist(n,vector<int>(n,inf));
        for(int k=0;k<n;k++){
            for(int u=0;u<n;u++){
                for(int v=0;v<n;v++){
                    dist[u][v]=min(dist[u][v],dist[u][k]+dist[k][v]);
                }
            }
        }
        int ans=-1;
        int min_nb=inf;
        for(int u=0;u<n;u++){//正序遍历求最大编号
            int nb=0;
            for(int v=0;v<n;v++){
                if(u!=v && dist[u][v]<inf){
                    nb++;
                }
            }
            if(min_nb>=nb){//要取到等
                min_nb=nb;
                ans=u;
            }
        }
        return ans;
    }
};

解题总结

        看到任意2点最短路径考虑用floyd算法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值