最短路

Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 24283    Accepted Submission(s): 10465

Problem Description
在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt。但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以现在他们想要寻找最短的从商店到赛场的路线,你可以帮助他们吗?
 
Input
输入包括多组数据。每组数据第一行是两个整数N、M(N<=100,M<=10000),N表示成都的大街上有几个路口,标号为1的路口是商店所在地,标号为N的路口是赛场所在地,M则表示在成都有几条路。N=M=0表示输入结束。接下来M行,每行包括3个整数A,B,C(1<=A,B<=N,1<=C<=1000),表示在路口A与路口B之间有一条路,我们的工作人员需要C分钟的时间走过这条路。 输入保证至少存在1条商店到赛场的路线。
 
Output
对于每组输入,输出一行,表示工作人员从商店走到赛场的最短时间
 
Sample Input
2 1
1 2 3
3 3
1 2 5
2 3 5
3 1 2
0 0
 
Sample Output
3
2
 
 
Dijkstra算法,第二题。和hdu2066相似;ps:http://www.cnblogs.com/yuyixingkong/p/3455931.html哈哈!秒过。
晚上继续努力。
详见代码:

#include<iostream>
#include<cstring>
#include<cstdio>
#define INF 0xfffffff//很大的数,16进制 f代表15;
#define MAX 1005
using namespace std;
int map[MAX][MAX];
int visit[MAX],dis[MAX];
int N,M,n;
int Dijkstra()
{
int i,j;
// memset(visit,false,sizeof(visit)); 31ms 所以可以不写memset就不写
for(i=;i<=n;i++)
{
dis[i]=map[][i];
visit[i]=false; // 15ms
}
dis[]=;
visit[]=true;
for(i=;i<=n;i++)
{
int tmp=INF;
int k;
for(j=;j<=n;j++)
if(!visit[j]&&dis[j]<tmp)
tmp=dis[k=j];
//if(tmp==INF) break; //调试的时候用
visit[k]=true;
for(j=;j<=n;j++)
{
if(!visit[j]&&dis[j]>dis[k]+map[k][j])
dis[j]=dis[k]+map[k][j];
}
}
return dis[n];
}
int main()
{
int i,j,k,a,b,time;
while(scanf("%d%d",&N,&M),N||M)
{
for(i=;i<MAX;i++)
for(j=;j<MAX;j++)
map[i][j]=INF;
for(i=;i<=M;i++)
{
scanf("%d%d%d",&a,&b,&time);
if(time<map[a][b])
map[a][b]=map[b][a]=time;//双向的
} n=N+;
map[][]=map[][]=;
map[n][N]=map[N][n]=;
printf("%d\n",Dijkstra());
}
return ;
}

真的是模版不信,你看我源代码:

#include<iostream>
#include<cstring>
#include<cstdio>
#define INF 0xfffffff//很大的数,16进制 f代表15;
#define MAX 1005
using namespace std;
int map[MAX][MAX];
int visit[MAX],dis[MAX];
int N,M,n;
int Dijkstra()
{
int i,j;
// memset(visit,false,sizeof(visit)); 31ms 所以可以不写memset就不写
for(i=;i<=n;i++)
{
dis[i]=map[][i];
visit[i]=false; // 15ms
}
dis[]=;
visit[]=true;
for(i=;i<=n;i++)
{
int tmp=INF;
int k;
for(j=;j<=n;j++)
if(!visit[j]&&dis[j]<tmp)
tmp=dis[k=j];
//if(tmp==INF) break; //调试的时候用
visit[k]=true;
for(j=;j<=n;j++)
{
if(!visit[j]&&dis[j]>dis[k]+map[k][j])
dis[j]=dis[k]+map[k][j];
}
}
return dis[n];
}
int main()
{
int i,j,k,a,b,time;
while(scanf("%d%d",&N,&M),N||M)
{
for(i=;i<MAX;i++)
for(j=;j<MAX;j++)
map[i][j]=INF;
// n=0;
for(i=;i<=M;i++)
{
scanf("%d%d%d",&a,&b,&time);
if(time<map[a][b])
map[a][b]=map[b][a]=time;//双向的
// if(a>n) n=a;
// if(b>n) n=b;
} // n++;// 最大地点数+1
n=N+; /* for(i=1;i<=S;i++)
{
scanf("%d",&a);
map[0][a]=map[a][0]=0;//与原点相连的,距离为0;
} for(i=1;i<=D;i++)
{
scanf("%d",&a);
map[n][a]=map[a][n]=0;//终点n到想去的地方的距离是0;
}*/
map[][]=map[][]=;
map[n][N]=map[N][n]=;
printf("%d\n",Dijkstra());
}
return ;
}

刚刚开始学习,要好好看代码;理解透才行。。。

 

最短路(hdu2544)Dijkstra算法二的更多相关文章

  1. 最短路和次短路问题,dijkstra算法

    /*  *题目大意:  *在一个有向图中,求从s到t两个点之间的最短路和比最短路长1的次短路的条数之和;  *  *算法思想:  *用A*求第K短路,目测会超时,直接在dijkstra算法上求次短路; ...

  2. 单源最短路:Dijkstra算法 及 关于负权的讨论

    描述: 对于图(有向无向都适用),求某一点到其他任一点的最短路径(不能有负权边). 操作: 1. 初始化: 一个节点大小的数组dist[n] 源点的距离初始化为0,与源点直接相连的初始化为其权重,其他 ...

  3. Dijkstra算法(二)之 C++详解

    本章是迪杰斯特拉算法的C++实现. 目录 1. 迪杰斯特拉算法介绍 2. 迪杰斯特拉算法图解 3. 迪杰斯特拉算法的代码说明 4. 迪杰斯特拉算法的源码 转载请注明出处:http://www.cnbl ...

  4. HDOJ 2544 最短路(最短路径 dijkstra算法,SPFA邻接表实现,floyd算法)

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  5. [Swust OJ 842]--实验室和食堂(最短路,Dijkstra算法)

    题目链接:http://acm.swust.edu.cn/problem/842/ Time limit(ms): 1000 Memory limit(kb): 10000   Description ...

  6. 最短路之 Dijkstra 算法

    普通的 Dijkstra 这是一种运用贪心的单源最短路算法,就是求从一个节点出发,到任意一个点的最短距离 首先我们要一个图 假设要求从 1 开始的单源最短路 dis[] 表示最短路数组, vis[] ...

  7. HDU - 2544最短路 (dijkstra算法)

    HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...

  8. 最短路之Dijkstra算法

    1. 邻接矩阵 int cost[MAX_V][MAX_V]; //assume cost[u][v]>0 int d[MAX_V]; bool used[MAX_V]; void Dijkst ...

  9. hdu2544 最短路 Dijkstra算法

    最短路(Dijkstra算法模板题) Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Other ...

随机推荐

  1. XSS 跨站脚本攻击 的防御解决方案

    虽然说在某些特殊情况下依然可能会产生XSS,但是如果严格按照此解决方案则能避免大部分XSS攻击. 原则:宁死也不让数据变成可执行的代码,不信任任何用户的数据,严格区数据和代码. XSS的演示 Exam ...

  2. Python 绝技 —— TCP服务器与客户端

    i春秋作家:wasrehpic 0×00 前言 「网络」一直以来都是黑客最热衷的竞技场.数据在网络中肆意传播:主机扫描.代码注入.网络嗅探.数据篡改重放.拒绝服务攻击……黑客的功底越深厚,能做的就越多 ...

  3. underscore.js源码研究(2)

    概述 很早就想研究underscore源码了,虽然underscore.js这个库有些过时了,但是我还是想学习一下库的架构,函数式编程以及常用方法的编写这些方面的内容,又恰好没什么其它要研究的了,所以 ...

  4. 对drf的初步认识

    web应用模式 1.前后端不分离 在前后端不分离的应用模式中,前端页面看到的效果都是由后端控制,由后端渲染页面或重定向,也就是后端需要控制前端的展示,前端与后端的耦合度很高. 这种应用模式比较适合纯网 ...

  5. idea 安装mybatis plugin (mybatis插件)

    注意:可以用免费版本的,就是下面没有 被红框圈中的 Free Mybatis Plugin 安装上以后需要破解,先找到下面的文件 打开文件,设置其中的key 和 value : 这里面的key 和 v ...

  6. Linux在终端和控制台下复制粘贴命令快捷键

    1.在终端下: (1)复制命令:Ctrl + Shift + C 组合键. (2)粘贴命令:Ctrl + Shift + V 组合键. 2.在控制台下:(即vi编辑过程中) (1)复制命令:Ctrl ...

  7. c++中文件读取

    对于C++编译运行文件,我使用过两个编译器,一个是visual studio 2013,另外一个是devcpp,推荐使用devcpp. vs的特点是界面整洁清晰,但是需要收费,这是微软的,并且在电脑上 ...

  8. PHP:WampServer下如何安装多个版本的PHP、mysql、apache

    作为Web开发人员,在机器上安装不同版本的php,apache和mysql有时是很有必要的. 今天,我在调试一套PHP程序的时候,该程序中使用的某些函数在低版本中无法使用,所以只能在搞个高版本的php ...

  9. C# 多线程学习系列三之CLR线程池系列之ThreadPool

    一.CLR线程池 1.进程和CLR的关系一个进程可以只包含一个CLR,也可以包含多个CLR2.CLR和AppDomain的关系一个CLR可以包含多个AppDomain3.CLR和线程池的关系一个CLR ...

  10. NIO基础之同步、异步、阻塞、非阻塞

    这里区分几个概念,也是常见但是容易混淆的概念,就是标题中的同步.异步.阻塞.非阻塞. 一.同步与异步 同步与异步,关心的是消息通信的机制.也就是调用者和被调用者之间,消息是如何进行通知的.如果是调用者 ...