zoukankan      html  css  js  c++  java
  • pta—紧急救援 (dijkstra)

    题目连接:https://pintia.cn/problem-sets/994805046380707840/problems/994805073643683840 

    题面:

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

    输入格式:

    输入第一行给出4个正整数N、M、S、D,其中N(2<=N<=500)是城市的个数,顺便假设城市的编号为0~(N-1);M是快速道路的条数;S是出发地的城市编号;D是目的地的城市编号。第二行给出N个正整数,其中第i个数是第i个城市的救援队的数目,数字间以空格分隔。随后的M行中,每行给出一条快速道路的信息,分别是:城市1、城市2、快速道路的长度,中间用空格分开,数字均为整数且不超过500。输入保证救援可行且最优解唯一。

    输出格式:

    第一行输出不同的最短路径的条数和能够召集的最多的救援队数量。第二行输出从S到D的路径中经过的城市编号。数字间以空格分隔,输出首尾不能有多余空格。
    输入样例:
    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

    题解:dijkstra计算最短路的长度,结果保存在数组d中,数组path记录最短路的条数。 利用前缀数组pre记录最短路的路径,利用栈输出; 数组val表示每个点的权值,最短路中权值最大的保存在数组tol中。

     1 #include<stdio.h>
     2 #include<algorithm>
     3 #include<string.h>
     4 #include<stack>
     5 using namespace std;
     6 
     7 const int INF=0x3f3f3f3f;
     8 const int maxn=510;
     9 int pre[maxn],path[maxn],tol[maxn],val[maxn];
    10 int cost[maxn][maxn],d[maxn],used[maxn];
    11 int n,m;
    12 
    13 void init()
    14 {
    15     fill(d,d+n,INF);
    16     memset(used,0,sizeof used);
    17     memset(pre,-1,sizeof pre);
    18 }
    19 
    20 void dijkstra(int s)
    21 {
    22     init();
    23     d[s]=0;
    24     path[s]=1;
    25     tol[s]=val[s];
    26     while(1){
    27         int v=-1;
    28         for(int u=0;u<n;u++)
    29             if(!used[u]&&(v==-1||d[u]<d[v])) v=u;
    30         if(v==-1) break;
    31         used[v]=1;
    32         for(int u=0;u<n;u++){
    33             if(!used[u]&&cost[u][v]!=INF){
    34                 if(d[u]>d[v]+cost[v][u]){
    35                     d[u]=d[v]+cost[v][u];
    36                     pre[u]=v;
    37                     path[u]=path[v];
    38                     tol[u]=tol[v]+val[u];
    39                 }
    40                 else if(d[u]==d[v]+cost[v][u]){
    41                     path[u]+=path[v];
    42                     if(tol[u]<tol[v]+val[u]){
    43                         pre[u]=v;
    44                         tol[u]=tol[v]+val[u];
    45                     }
    46                 }
    47             }
    48         }
    49     }
    50 }
    51 
    52 void print(int t)
    53 {
    54     stack<int> q;
    55     for(;t!=-1;t=pre[t])
    56         q.push(t);
    57     while(!q.empty()){
    58         int k=q.top();
    59         q.pop();
    60         printf("%d",k);
    61         if(!q.empty()) printf(" ");
    62         else printf("
    ");
    63     }
    64 }
    65 
    66 int main()
    67 {
    68     int s,t;
    69     scanf("%d%d%d%d",&n,&m,&s,&t);
    70     for(int i=0;i<n;i++)
    71         scanf("%d",&val[i]);
    72     for(int i=0;i<n;i++){
    73         for(int j=0;j<n;j++){
    74             if(i!=j) cost[i][j]=INF;
    75         }
    76     }
    77     for(int i=0;i<m;i++){
    78         int u,v,w;
    79         scanf("%d%d%d",&u,&v,&w);
    80         cost[u][v]=cost[v][u]=w;
    81     }
    82     dijkstra(s);
    83     printf("%d %d
    ",path[t],tol[t]);
    84     print(t);
    85     return 0;
    86 }
    View Code
  • 相关阅读:
    嵌入式驱动开发之sensor---sensor 图形传感器调试
    时下世界上最先进的液晶面板技术---ips
    多媒体开发之rtp 打包发流---udp 丢包问题
    多媒体开发之rtp 打包发流---同网段其他机子sdp 播放不了
    AutoCAD LoadLibrary Failed with error 126 Message
    OpenCV获取与设置像素点的值的几个方法
    四元数与旋转
    圆点博士小四轴主程序状态机结构
    四元数(Quaternion)和旋转 +欧拉角
    PID控制算法
  • 原文地址:https://www.cnblogs.com/lilibuxiangtle/p/12227714.html
Copyright © 2011-2022 走看看