zoukankan      html  css  js  c++  java
  • hdu 1690 Bus System

    floyd算法。这题目比较操蛋,首先INF需要比较大,我选择了INF = 0xffffffffffffff。还有一点就是%lld会挂掉的,用%I64d才能AC。

    #include<cstdio>
    #include<cmath>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    const int maxn = 105;
    __int64 INF = 0xffffffffffffff;
    __int64 x[maxn], jz[maxn][maxn], A[maxn][maxn];
    int n, m;
    void floyd()
    {
        int i, j, k;
        for (i = 0; i <= n; i++)
        for (j = 0; j <= n; j++)
            A[i][j] = jz[i][j];
    
        for (k = 1; k <= n; k++)
        {
            for (i = 1; i <= n; i++)
            {
                for (j = 1; j <= n; j++)
                {
                    if (k == i || k == j) continue;
                    if (A[i][k] == INF || A[k][j] == INF) continue;
                    else
                    {
                        if (A[i][k] + A[k][j] < A[i][j])
                        {
                            A[i][j] = A[i][k] + A[k][j];
                        }
                    }
                }
            }
        }
    }
    
    int main()
    {
        __int64 l1, l2, l3, l4, c1, c2, c3, c4;
        int i, j, sb, _;
        scanf("%d", &sb);
        for (_ = 1; _ <= sb; _++)
        {
            scanf("%I64d%I64d%I64d%I64d%I64d%I64d%I64d%I64d", &l1, &l2, &l3, &l4, &c1, &c2, &c3, &c4);
            scanf("%d%d", &n, &m);
            for (i = 0; i <= n; i++)
            {
                for (j = 0; j <= n; j++)
                {
                    if (i == j) jz[i][j] = 0;
                    else jz[i][j] = INF;
                }
            }
            for (i = 1; i <= n; i++) scanf("%I64d", &x[i]);
            for (i = 1; i <= n; i++)
            {
                for (j = 1; j <= n; j++)
                {
                    if (i == j) continue;
                    __int64 jl = abs(x[i] - x[j]);
                    if (jl > 0 && jl <= l1){ jz[i][j] = c1; jz[j][i] = c1; }
                    else if (jl > l1 && jl <= l2){ jz[i][j] = c2; jz[j][i] = c2; }
                    else if (jl > l2 && jl <= l3) { jz[i][j] = c3; jz[j][i] = c3; }
                    else if (jl > l3 && jl <= l4) { jz[i][j] = c4; jz[j][i] = c4; }
                }
            }
            floyd();
            int u, v;
            printf("Case %d:
    ", _);
            for (i = 0; i < m; i++)
            {
                scanf("%d%d", &u, &v);
                if (A[u][v] != INF)printf("The minimum cost between station %d and station %d is %I64d.
    ", u, v, A[u][v]);
                else printf("Station %d and station %d are not attainable.
    ", u, v);
            }
        }
        return 0;
    }
  • 相关阅读:
    PHP实现微信开发中提现功能(企业付款到用户零钱)
    微信开发企业支付到银行卡PHP
    详解PHP实现定时任务的五种方法
    PHP实现执行定时任务的几种思路详解
    Laravel 去掉访问后面的 “public”
    laravel 中数据库查询结果自动转数组
    怎样才能去掉图片上的二维码
    用PS修改PNG格式图标的颜色
    消除浏览器对input输入框的自动填充
    知网---压缩传感研究现状
  • 原文地址:https://www.cnblogs.com/zufezzt/p/4521366.html
Copyright © 2011-2022 走看看