HDU-1869-六度分离

本文详细介绍Floyd算法原理及其实现方式,并通过一个具体的ACM竞赛题目来演示如何使用该算法解决任意两点间的最短路径问题。文章还提供了一个完整的C++实现代码示例。
部署运行你感兴趣的模型镜像

ACM模版

描述

描述

题解

floyd搞搞事情,求任意两点之间的距离是否超过7,默认每条路径长度为1。

代码

#include <iostream>
#include <cstring>

using namespace std;

/*
 *  Floyd算法,求从任意节点i到任意节点j的最短路径
 *  cost[][]:初始化为INF(cost[i][i]:初始化为0)
 */
const int MAXN = 100;

int cost[MAXN][MAXN];
int lowcost[MAXN][MAXN];
int path[MAXN][MAXN];

void Floyd(int n)
{
    memcpy(lowcost, cost, sizeof(cost));
    memset(path, -1, sizeof(path));

    for (int k = 0; k < n; k++)
    {
        for (int i = 0; i < n; i++)
        {
            for (int j = 0; j < n; j++)
            {
                if (lowcost[i][j] > (lowcost[i][k] + lowcost[k][j]))
                {
                    lowcost[i][j] = lowcost[i][k] + lowcost[k][j];
                    path[i][j] = k;
                }
            }
        }
    }
    return ;
}

int main(int argc, const char * argv[])
{
    int N, M;
    while (cin >> N >> M)
    {
        memset(cost, 0x3f, sizeof(cost));

        int a, b;
        for (int i = 0; i < M; i++)
        {
            scanf("%d%d", &a, &b);
            cost[a][b] = cost[b][a] = 1;
        }

        Floyd(N);

        bool flag = true;
        for (int i = 0; i < N; i++)
        {
            for (int j = i + 1; j < N; j++)
            {
                if (lowcost[i][j] > 7)
                {
                    flag = false;
                    break;
                }
            }
        }

        if (flag)
        {
            cout << "Yes\n";
        }
        else
        {
            cout << "No\n";
        }
    }

    return 0;
}

参考

《最短路》

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值