最短路(hdu2544)Dijkstra算法二
最短路
Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 24283 Accepted Submission(s): 10465
#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算法二的更多相关文章
- 最短路和次短路问题,dijkstra算法
/* *题目大意: *在一个有向图中,求从s到t两个点之间的最短路和比最短路长1的次短路的条数之和; * *算法思想: *用A*求第K短路,目测会超时,直接在dijkstra算法上求次短路; ...
- 单源最短路:Dijkstra算法 及 关于负权的讨论
描述: 对于图(有向无向都适用),求某一点到其他任一点的最短路径(不能有负权边). 操作: 1. 初始化: 一个节点大小的数组dist[n] 源点的距离初始化为0,与源点直接相连的初始化为其权重,其他 ...
- Dijkstra算法(二)之 C++详解
本章是迪杰斯特拉算法的C++实现. 目录 1. 迪杰斯特拉算法介绍 2. 迪杰斯特拉算法图解 3. 迪杰斯特拉算法的代码说明 4. 迪杰斯特拉算法的源码 转载请注明出处:http://www.cnbl ...
- HDOJ 2544 最短路(最短路径 dijkstra算法,SPFA邻接表实现,floyd算法)
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- [Swust OJ 842]--实验室和食堂(最短路,Dijkstra算法)
题目链接:http://acm.swust.edu.cn/problem/842/ Time limit(ms): 1000 Memory limit(kb): 10000 Description ...
- 最短路之 Dijkstra 算法
普通的 Dijkstra 这是一种运用贪心的单源最短路算法,就是求从一个节点出发,到任意一个点的最短距离 首先我们要一个图 假设要求从 1 开始的单源最短路 dis[] 表示最短路数组, vis[] ...
- HDU - 2544最短路 (dijkstra算法)
HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...
- 最短路之Dijkstra算法
1. 邻接矩阵 int cost[MAX_V][MAX_V]; //assume cost[u][v]>0 int d[MAX_V]; bool used[MAX_V]; void Dijkst ...
- hdu2544 最短路 Dijkstra算法
最短路(Dijkstra算法模板题) Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
随机推荐
- Android---------------ContentProvider的学习
1.Uri uri = Intent.getData()------------->可以获得Uri的地址 2.Cursor cursor = getContentResolver().quer ...
- SQL Server 用户'NT AUTHORITY\IUSR' 登录失败
今天打开网站时,突然报这个错误,平时都好好的 Cannot open database "JMECC" requested by the login. The login fail ...
- updateByPrimaryKey 和 updateByPrimaryKeySelective
1. 数据库记录 2. updateByPrimaryKey Preparing: UPDATE t_token_info SET entity_id = ?,entity_type = ?,time ...
- odoo开发笔记-tree列表视图拖拽排序
odoo列表tree视图 拖拽排序 实现效果: 实现方式: 模型中定义字段: class CusYourModel(models.Model): """ 你的模型 &qu ...
- MVC3学习:Sql Server2005中时间类型DateTime的显示
在Sql Server2005中,如果将某字段定义成日期时间类型DateTime,那么在视图中会默认显示成年月日时分秒的方式(如 2013/8/6 13:37:33) 如果只想显示成年月日形式,不要时 ...
- (转) argparse — 解析命令参数和选项
原文地址:https://pythoncaff.com/docs/pymotw/argparse-command-line-option-and-argument-parsing/166 https: ...
- Spring4 mvc+maven 框架搭建(3)
经过前面两个环节,spring mvc的原料已经准备好了,现在就可以正式开始搭建springmvc框架了. 首先先介绍介绍搭建的框架具有的功能: 1)集成log4j,配置好日志相关并可以打印出相关的日 ...
- 确保线程安全下使用Queue的Enqueue和Dequeue
场景是这样,假设有一台设备会触发类型为Alarm的告警信号,并把信号添加到一个Queue结构中,每隔一段时间这个Queue会被遍历检查,其中的每个Alarm都会调用一个相应的处理方法.问题在于,检查机 ...
- 浏览器对CSS小数点的解析——坑
在写移动端项目时,为了将一个元素垂直居中,于是我将元素的高和行高设置成一样的,但是显示出来的结果,却让人不得其解,如下: 可以看到按钮的底部有一条缝隙,一开始以为是代码写错了,于是检查了一下,发现没啥 ...
- mysql数据库中实现内连接、左连接、右连接
原文:http://www.cnblogs.com/xwdreamer/archive/2010/12/15/2297058.html 内连接:把两个表中数据对应的数据查出来 外连接:以某个表为基础把 ...