#include<stdio.h>

#include<string.h>

#define N 200

#define inf 999999999999

__int64 map[N][N],dis[N];

char s[N][40];

void dijkstra(__int64 s,__int64 t,__int64 n) {

    __int64 visit[N],u,min,i,j;

    for(i=0;i<n;i++) {

        visit[i]=1;

        dis[i]=map[s][i];

    }

    visit[s]=0;

    for(i=0;i<n-1;i++) {

        min=inf;

        for(j=0;j<n;j++)

            if(min>dis[j]&&visit[j]) {

                min=dis[j];

                u=j;

            }

            visit[u]=0;

            for(j=0;j<n;j++)

                if(visit[j]&&map[u][j]<inf) {

                    if(dis[j]>dis[u]+map[u][j])

                        dis[j]=dis[u]+map[u][j];

                }

                }

}

int main() {

    __int64 t,n,m,count,kai,jie,i,j;

    char start[40],end[40],str[40],str1[40];

    while(scanf("%I64d",&n),n!=-1) {

        for(i=0;i<=160;i++) {

            dis[i]=inf;

            for(j=0;j<=160;j++)

                map[i][j]=i==j?0:inf;

        }

        scanf("%s%s",start,end);

        count=0;

        while(n--) {

            scanf("%s%s%I64d",str,str1,&t);

             for(i=0;i<count;i++)

                 if(strcmp(s[i],str)==0) {

                     kai=i;

                     break;

                 }

                 if(i==count) {

                     strcpy(s[count],str);

                     kai=count;

                     count++;

                 }

                 for(i=0;i<count;i++)

                     if(strcmp(s[i],str1)==0) {

                         jie=i;

                         break;

                     }

                     if(i==count) {

                         strcpy(s[count],str1);

                         jie=count;

count++;

                     }

                     map[kai][jie]=map[jie][kai]=t;

        }

kai=-1;

jie=-1;

        for(i=0;i<count;i++) {

            if(strcmp(s[i],start)==0)

                kai=i;

            if(strcmp(s[i],end)==0)

                jie=i;

        }

if(kai==-1||jie==-1) {//一定是||刚开始时&&一直错

printf("-1\n");

continue;

}

        dijkstra(kai,jie,count);

        if(dis[jie]<inf)

        printf("%I64d\n",dis[jie]);

        else

            printf("-1\n");

    }

    return 0;

}

hdu 2112的更多相关文章

  1. hdu 2112 (最短路+map)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=2112 HDU Today Time Limit: 15000/5000 MS (Java/Others)  ...

  2. hdu 2112 HDU Today

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2112 HDU Today Description 经过锦囊相助,海东集团终于度过了危机,从此,HDU的 ...

  3. HDU 2112 HDU Today(Dijkstra)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2112 HDU Today Time Limit: 15000/5000 MS (Java/Others ...

  4. HDU Today hdu 2112

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=2112 文章末有一些相应的测试数据供参考. 此题就是一个求最短路的问题,只不过现在的顶点名称变成了字符串而不 ...

  5. hdu 2112 HDU Today (floyd算法)

    这道题貌似在原来学长给我们的搞的小比赛中出过! 这次又让我遇到,果断拿下! 不过方法很蠢,跑了1000多ms,虽然要求5000ms以内! 题目就是给你一些位置之间的距离,然后再让你求特定的两点之间的距 ...

  6. 【hdu 2112】 HDU Today ( 最短路 Dijkstra)(map)

    http://acm.hdu.edu.cn/showproblem.php?pid=2112 这道题给了一个将字符串与int对应的思路,就是使用map 这道题答案对了,但是没有AC,我也不知道为什么. ...

  7. HDU 2112 Today(Dijkstra+map)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2112 题目大意: 经过锦囊相助,海东集团终于度过了危机,从此,HDU的发展就一直顺风顺水,到了2050 ...

  8. hdu 2112 HDU Today (最短路)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2112 题目大意:给出起点和终点,然后算出最短的路. 不过有好多细节要注意: (1)起始点和终止点相等的 ...

  9. hdu 2112 HDU Today 解题报告

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2112 题目意思:又是求最短路的,不过结合埋字符串来考查. 受之前1004 Let the Balloo ...

  10. HDU 2112 HDU Today (Dijkstra算法)

    HDU Today Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

随机推荐

  1. 配置组件的 props

    组件是相互独立.可复用的单元,一个组件可能在不同地方被用到.但是在不同的场景下对这个组件的需求可能会根据情况有所不同,例如一个点赞按钮组件,在我这里需要它显示的文本是“点赞”和“取消”,当别的同事拿过 ...

  2. oracle PL、SQL(概念)

    一.PL/SQL简介. Oracle PL/SQL语言(Procedural Language/SQL)是结合了结构化查询和Oracle自身过程控制为一体的强大语言,PL/SQL不但支持更多的数据类型 ...

  3. AJPFX对选择和冒泡两种排序的理解

    冒泡排序和直接选择排序都是排序中比较简单和容易实现的算法,先简单说说两者的区别:先以按照元素从小到大为:冒泡排序:将相邻元素两两比较,如果有比较大的,就把比较大的放在右边,这样的结果就是一轮排序完毕后 ...

  4. 后TOS时代的码头数字化生产力

    之前看过一篇文章是,是INFORM的副总裁写的关于以TOS外挂模式提升码头生产效能的文章.文章对外挂模式的总结挺好的,我最近也一直从事这块的工作,以此文梳理一下前面的经验,记录一下自己的感想. TOS ...

  5. java8的lambda表达式,将List<DTO> 转为 List<DO>

    将List<PhoneDTO>转为List<PhoneDO>,通过java8的lambda表达式来操作,比传统的for循环精简很多: /** * List<PhoneDT ...

  6. http://bbs.chinaunix.net/thread-1463276-1-1.html

    http://bbs.chinaunix.net/thread-1463276-1-1.html

  7. Android获取声音长度

    代码 MediaMetadataRetriever metaRetriever = new MediaMetadataRetriever(); metaRetriever.setDataSource( ...

  8. Linux环境下手动配置sbt

    一.下载sbt安装包 从sbt官网下载地址:http://www.scala-sbt.org/download.html下载安装包,以sbt-0.13.13.tgz为例. 二.安装 1.将下载的二进制 ...

  9. Hadoop 安装过程中出现的问题

    1.hadoop-daemon.sh start namenode 启动失败 查看hadoop/logs 下面的日志 出现 2017-04-11 15:35:13,860 WARN org.apach ...

  10. HTML5应用 + Cordova = 平台相关的混合应用

    Jerry之前的一篇文章 SAP Fiori应用的三种部署方式 曾经提到SAP Fiori应用的三种部署方式: On Premise环境下以ABAP BSP应用作为Fiori应用部署和运行的载体 部署 ...