U167571 信使

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 103, M = 116300, INF = 0x3f3f3f3f;
typedef long long int LL;
typedef unsigned long long int ULL;
const int mod = 1000000007;
#define x first
#define y second
typedef pair<int, LL> PIL;
typedef pair<int, int> PII;
int n, m;
int g[N][N];
int floyd()
{
    for (int k = 1; k <= n; k++)
    {
        for (int i = 1; i <= n; i++)
        {
            for (int j = 1; j <= n; j++)
            {
                if (g[i][j] > g[i][k] + g[k][j])
                {
                    g[i][j] = g[i][k] + g[k][j];//利用floyd算法更新两个点之间的路径
                }
            }
                }
    }
    int res = 0;
    for (int i = 1; i <= n; i++)
    {
        if (g[1][i] == INF)
            return -1;
        res = max(res, g[1][i]);
    }//如果有个点到1(指挥部)的距离为INF,则说明有个地方信息传不到,输出-1,否则输出最晚传达到的阵营所需的时间。
    return res;
}
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0), cout.tie(0);
    cin >> n >> m;
    memset(g, 0x3f, sizeof g);
    for (int i = 0; i < m; i++)
    {
        int a, b, c;
        cin >> a >> b >> c;
        g[a][b] = g[b][a] = min(g[a][b], c);
    }
    int res = floyd();
    cout << res << endl;
    return 0;
}
相关推荐
β添砖java6 小时前
vivo响应式官网
前端·css·html·1024程序员节
成震19716 小时前
esp-idf 最简操作
1024程序员节
2301_803554526 小时前
详细解释 std::thread t1(&ThreadPrinter::print, &printer, 1);
1024程序员节
喜葵7 小时前
微信小程序第三方代开发模式技术调研与实践
1024程序员节
云起SAAS7 小时前
空号号码状态检测抖音快手微信小程序看广告流量主开源
ai编程·1024程序员节·看广告变现轻·空号号码状态检测
MarkHD7 小时前
Dify从入门到精通 第27天 在Dify中构建天气查询机器人
1024程序员节
진영_7 小时前
深度学习打卡第TR5周:Transformer实战:文本分类
1024程序员节
傻童:CPU8 小时前
C语言需要掌握的基础知识点之线性表
c语言·1024程序员节
Heavy sea8 小时前
Linux串口应用编程
linux·c语言·1024程序员节