最短路

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. Fiddler工具使用介绍三

    我们知道Fiddler是位于客户端和服务器之间的代理,它能够记录客户端和服务器之间的所有 HTTP请求,可以针对特定的HTTP请求,分析请求数据.设置断点.调试web应用.修改请求的数据,甚至可以修改 ...

  2. SAS Shortcut Keys

    最常用的键有F3(运行代码).F6(查看log信息).Ctrl + / (注释代码).Ctrl + Shift + / (取消代码注释) SAS系统一共有4类快捷键,其中部分有重复, 第一类可自定义. ...

  3. ViewPager无限滑动

    2016-6-19 前言 View轮播效果在app中很常见,一想到左右滑动的效果就很容易想到使用ViewPager来实现.对于像我们常说的banner这样的效果,具备无限滑动的功能是可以用ViewPa ...

  4. cad2018卸载/安装失败/如何彻底卸载清除干净cad2018注册表和文件的方法

    cad2018提示安装未完成,某些产品无法安装该怎样解决呢?一些朋友在win7或者win10系统下安装cad2018失败提示cad2018安装未完成,某些产品无法安装,也有时候想重新安装cad2018 ...

  5. Shell - 简明Shell入门01 - 第一个脚本(HelloShell)

    示例脚本及注释 #!/bin/bash echo "hello shell!" # 打印字符串"hello shell!" echo "Date: & ...

  6. js缓存问题,修改js后代码不生效

    问题描述 最近在上线新版本项目的时候,发现有的用户的操作还是调用的老版本JS里面的内容,这样就造成原来新的JS里面加上的限制不能限制用户的操作,从而导致用户可以重复操作. 问题产生原因 如果在用户之前 ...

  7. odoo开发笔记 -- odoo和postgresql数据库导入相关

    odoo数据库 导入.导出 首先odoo框架下postgresql数据库中,表结构的存储方式: 存在id(小写),并没有所谓的外部ID 例如数据库中的国家表:模块名_tb_country   (注意: ...

  8. (转)pathlib路径库使用详解

    原文:https://xin053.github.io/2016/07/03/pathlib%E8%B7%AF%E5%BE%84%E5%BA%93%E4%BD%BF%E7%94%A8%E8%AF%A6 ...

  9. gvim配置相关

    用 vundle 来管理 vim 插件(包含配置文件vimrc和gvimrc) gvim插件管理神器:vundle的安装与使用 Vim插件管理Vundle Linux 下VIM的配置 Vim配置系列( ...

  10. FactoryMethod工厂方法模式升级成AbstractFactory抽象工厂模式

    具体参考抽象工厂(AbstractFactory)模式-创建型模式,本文在FactoryMethod工厂方法模式(创建型模式)的基础上进行业务进一步抽象,不做详细原理介绍. 1.在FactoryMet ...