zoukankan      html  css  js  c++  java
  • HDU 2112 HDU Today(最短路径+map)

    HDU Today
    Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 38862    Accepted Submission(s): 9377


    Problem Description
    经过锦囊相助,海东集团终于度过了危机,从此,HDU的发展就一直顺风顺水,到了2050年,集团已经相当规模了,据说进入了钱江肉丝经济开发区500强。这时候,XHD夫妇也退居了二线,并在风景秀美的诸暨市浬浦镇陶姚村买了个房子,开始安度晚年了。
    这样住了一段时间,徐总对当地的交通还是不太了解。有时很郁闷,想去一个地方又不知道应该乘什么公交车,在什么地方转车,在什么地方下车(其实徐总自己有车,却一定要与民同乐,这就是徐总的性格)。
    徐总经常会问蹩脚的英文问路:“Can you help me?”。看着他那迷茫而又无助的眼神,热心的你能帮帮他吗?
    请帮助他用最短的时间到达目的地(假设每一路公交车都只在起点站和终点站停,而且随时都会开)。

    Input
    输入数据有多组,每组的第一行是公交车的总数N(0<=N<=10000);
    第二行有徐总的所在地start,他的目的地end;
    接着有n行,每行有站名s,站名e,以及从s到e的时间整数t(0<t<100)(每个地名是一个长度不超过30的字符串)。
    note:一组数据中地名数不会超过150个。
    如果N==-1,表示输入结束。

    Output
    如果徐总能到达目的地,输出最短的时间;否则,输出“-1”。

    Sample Input
    6
    xiasha westlake
    xiasha station 60
    xiasha ShoppingCenterofHangZhou 30
    station westlake 20
    ShoppingCenterofHangZhou supermarket 10
    xiasha supermarket 50
    supermarket westlake 10
    -1
     

    Sample Output
    50

    题解:模板题,将字符串映射成int再应用dijkstra法即可

    #include<iostream>
    #include<string.h>
    #include<algorithm>
    #include<map>
    using namespace std;
    const int INF=1e7+7;
    map<string,int>m;
    bool vis[1111];
    int d[1111][1111],dis[1111];
    int main()
    {
            int n;
            char s[33],e[33],st[33],ed[33];
            while(~scanf("%d",&n)&&n!=-1)
            {
                    for(int i=1;i<=155;i++){
                            vis[i]=0,dis[i]=INF;
                            for(int j=i;j<=155;j++)
                                    d[i][j]=d[j][i]=INF;
                    }
                    scanf("%s%s",s,e);
                    int cnt=0;m.clear();
                    m[s]=++cnt;
                    m[e]=++cnt;
                    for(int i=1;i<=n;i++){
                            int c;
                            scanf("%s%s%d",st,ed,&c);
                            if(!m[st])
                                    m[st]=++cnt;
                            if(!m[ed])
                                    m[ed]=++cnt;
                            d[m[st]][m[ed]]=d[m[ed]][m[st]]=min(d[m[st]][m[ed]],c);
                    }
                    if(!strcmp(s,e))
                            {printf("0
    ");continue;}
                    if(!n)
                            {printf("-1
    ");continue;}
                    for(int i=1;i<=cnt;i++)
                            dis[i]=d[1][i];
                    vis[1]=1;
                    for(int k=1;k<=cnt-1;k++)
                    {
                            int mi=INF,id=-1;
                            for(int i=1;i<=cnt;i++)
                                    if(!vis[i]&&mi>dis[i])
                                            mi=dis[id=i];
                            vis[id]=1;
                            if(id==2||mi==INF)
                                    break;
                            for(int i=1;i<=cnt;i++)
                                    if(!vis[i]&&dis[i]>d[id][i]+dis[id])
                                            dis[i]=dis[id]+d[id][i];
                    }
                    if(dis[2]<INF)
                            printf("%d
    ",dis[2]);
                    else
                            printf("-1
    ");
            }
            return 0;
    }
    
    
    
    
  • 相关阅读:
    一个主板上连接两个都有引导的盘
    pytorch查看模型weight与grad
    linux终端窗口字体缩放快捷键
    vim选中多行缩进(python多行缩进)与删除多行前面的空格
    python import 包的路径以及相对路径加载的问题
    pycharm中添加PATH变量
    Atom选中多行操作
    php扩展 swoole的安装与使用
    12121212
    linux系统下清理所有Redis缓存
  • 原文地址:https://www.cnblogs.com/aeipyuan/p/10262673.html
Copyright © 2011-2022 走看看