zoukankan      html  css  js  c++  java
  • 5-5 城市间紧急救援 (25分)【最短路spfa】

    5-5 城市间紧急救援   (25分)

    作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图。在地图上显示有多个分散的城市和一些连接城市的快速道路。每个城市的救援队数量和每一条连接两个城市的快速道路长度都标在地图上。当其他城市有紧急求助电话给你的时候,你的任务是带领你的救援队尽快赶往事发地,同时,一路上召集尽可能多的救援队。

    输入格式:

    输入第一行给出4个正整数NNMMSSDD,其中NN2le Nle 5002N500)是城市的个数,顺便假设城市的编号为0 ~ (N-1)(N1)MM是快速道路的条数;SS是出发地的城市编号;DD是目的地的城市编号。

    第二行给出NN个正整数,其中第ii个数是第ii个城市的救援队的数目,数字间以空格分隔。随后的MM行中,每行给出一条快速道路的信息,分别是:城市1、城市2、快速道路的长度,中间用空格分开,数字均为整数且不超过500。输入保证救援可行且最优解唯一。

    输出格式:

    第一行输出最短路径的条数和能够召集的最多的救援队数量。第二行输出从SSDD的路径中经过的城市编号。数字间以空格分隔,输出结尾不能有多余空格。

    输入样例:

    4 5 0 3
    20 30 40 10
    0 1 1
    1 3 2
    0 3 3
    0 2 2
    2 3 2
    

    输出样例:

    2 60
    0 1 3


    最短路;(更新等价

    #include <bits/stdc++.h>
    using namespace std;
    typedef long long LL;
    typedef unsigned long long ULL;
    typedef pair<int,int>PII;
    const double eps=1e-5;
    const double pi=acos(-1.0);
    const int mod=1e9+7;
    const int INF=0x3f3f3f3f;
    
    const int N=5e2+10;
    
    int ma[N][N];
    LL ways[N];
    int ww[N],pre[N],ans[N],num;
    PII dis[N];
    bool vis[N];
    int n,m,s,t;
    
    queue<int>q;
    void SPFA()
    {
        for(int i=0;i<n;i++)
        {
            ways[i]=0;
            vis[i]=0;
            dis[i].second=0;
            dis[i].first=INF;
        }
        pre[s]=-1;
        dis[s].first=0;
        dis[s].second=ww[s];
        vis[s]=1;
        ways[s]=1;
    
        q.push(s);
        while(!q.empty())
        {
            int u=q.front();
            q.pop();
            vis[u]=0;
            for(int i=0;i<n;i++)
            {
                if(ma[u][i]!=INF&&i!=u)
                {
                    if(dis[i].first>dis[u].first+ma[u][i])
                    {
                        pre[i]=u;
                        ways[i]=ways[u];
                        dis[i].first=dis[u].first+ma[u][i];
                        dis[i].second=dis[u].second+ww[i];
                        if(!vis[i])
                        {
                            q.push(i);
                            vis[i]=1;
                        }
                    }
                    else if(dis[i].first==dis[u].first+ma[u][i])
                    {
                        if(dis[i].second<dis[u].second+ww[i])
                        {
                            ways[i]+=ways[u];
                            pre[i]=u;
                            dis[i].second=dis[u].second+ww[i];
                            if(!vis[i])
                            {
                                q.push(i);
                                vis[i]=1;
                            }
                        }
                    }
                }
            }
        }
    //    printf("%d
    ",dis[t].first);
        printf("%lld %d
    ",ways[t],dis[t].second);
        int v=t;
        num=0;
        while(pre[v]!=-1)
        {
            ans[num++]=v;
            v=pre[v];
        }
        ans[num++]=s;
        printf("%d",ans[num-1]);
        for(int i=num-2;i>=0;i--)
            printf(" %d",ans[i]);
    }
    
    int main()
    {
        scanf("%d%d%d%d",&n,&m,&s,&t);
        for(int i=0;i<n;i++)
            scanf("%d",&ww[i]);
        for(int i=0;i<n;i++)
            for(int j=0;j<n;j++)
            {
                if(i==j) ma[i][i]=0;
                else ma[i][j]=ma[j][i]=INF;
            }
        int u,v,w;
        while(m--)
        {
            scanf("%d%d%d",&u,&v,&w);
            ma[u][v]=min(ma[u][v],w);
            ma[v][u]=ma[u][v];
        }
        SPFA();
        return 0;
    }
    
    
    





  • 相关阅读:
    设计模式——创建型设计模式总结(简单工厂、普通工厂、抽象工厂、建造者、原型和单例)
    网易游戏2011招聘笔试题+答案解析
    华为2011上机笔试题2+参考程序
    趋势科技2011校招笔试题+答案解析
    腾讯2012实习生笔试题2+答案解析
    浙商银行2011笔试题+答案解析
    Linux学习笔记(三)——权限管理
    PowerShell在多个文件中检索关键字
    Linux学习笔记(一)——入门
    PowerShell函数调用问题
  • 原文地址:https://www.cnblogs.com/keyboarder-zsq/p/6777519.html
Copyright © 2011-2022 走看看