hdoj 2544 最短路【dijkstra or spfa】
最短路
Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 38585 Accepted Submission(s): 16862
#include<stdio.h>
#include<string.h>
#define INF 0x3f3f3f
int map[110][110];
int visit[110];//记录最短距离节点
int lowtime[110];//记录最短 时间
int cross;
int dijkstra()
{
int j,i,mintime,next;
memset(visit,0,sizeof(visit));//初始化visit数组为0;
for(i=1;i<=cross;i++)
{
lowtime[i]=map[1][i]; //初始化lowtime数组为从1到i的时间
}
visit[1]=1;
for(i=1;i<cross;i++)
{
mintime=INF;
for(j=1;j<=cross;j++)
{
if(!visit[j]&&mintime>lowtime[j])
{
mintime=lowtime[j];
next=j;
}
}
visit[next]=1;
for(j=1;j<=cross;j++)
{
if(!visit[j]&&lowtime[j]>map[next][j]+lowtime[next])
lowtime[j]=map[next][j]+lowtime[next];
}
}
printf("%d\n",lowtime[cross]);
}
int main()
{
int road,x,y,c,i,j;
while(scanf("%d%d",&cross,&road)&&cross!=0&&road!=0)
{
for(i=1;i<cross;i++)
{
for(j=1;j<=cross;j++)
{
if(i==j)
map[i][j]=0;
else
map[i][j]=map[j][i]=INF;
}
}
while(road--)
{
scanf("%d%d%d",&x,&y,&c);
if(map[x][y]>c)
{
map[x][y]=map[y][x]=c;
}
}
dijkstra();
}
return 0;
}
spfa算法:
#include<stdio.h>
#include<string.h>
#include<queue>
#define MAX 110
#define INF 0x3f3f3f
using namespace std;
int n,m;
int map[MAX][MAX],low[MAX];
bool vis[MAX];
void init()
{
int i,j;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
map[i][j]=i==j?0:INF;
}
void spfa()
{
int i,j;
queue<int>q;
while(!q.empty())
q.pop();
memset(vis,0,sizeof(vis));
memset(low,0x3f,sizeof(low));
low[1]=0;
q.push(1);
vis[1]=true;
int u;
while(!q.empty())
{
u=q.front();
q.pop();
vis[u]=false;
for(i=1;i<=n;i++)
{
if(low[i]>low[u]+map[u][i]&&map[u][i]<INF)
{
low[i]=low[u]+map[u][i];
if(!vis[i])
{
vis[i]=true;
q.push(i);
}
}
}
}
printf("%d\n",low[n]);
}
int main()
{
int i,j;
while(scanf("%d%d",&n,&m),n|m)
{
init();
for(i=1;i<=m;i++)
{
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
if(map[a][b]>c)
map[a][b]=map[b][a]=c;
}
spfa();
}
return 0;
}
hdoj 2544 最短路【dijkstra or spfa】的更多相关文章
- HUD.2544 最短路 (Dijkstra)
HUD.2544 最短路 (Dijkstra) 题意分析 1表示起点,n表示起点(或者颠倒过来也可以) 建立无向图 从n或者1跑dij即可. 代码总览 #include <bits/stdc++ ...
- ACM: HDU 2544 最短路-Dijkstra算法
HDU 2544最短路 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descrip ...
- hdu 2544 最短路 Dijkstra
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目分析:比较简单的最短路算法应用.题目告知起点与终点的位置,以及各路口之间路径到达所需的时间, ...
- hdoj 2544 最短路
题目传送:http://acm.hdu.edu.cn/showproblem.php?pid=2544 分析:Dijkstra算法 //2013-10-30 10:01:25 Accepted 254 ...
- HDOJ 2544 最短路(最短路径 dijkstra算法,SPFA邻接表实现,floyd算法)
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submis ...
- HDOJ/HDU 2544 最短路---dijkstra算法
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 这题的思路可以见这里(同一类型):http://blog.csdn.net/xiaozhuaix ...
- hdoj 2544最短路
Problem Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以现在他们想要 ...
- hdoj 2544 最短路(最短路+Dijkstrea算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 思路分析:该问题给定一个无向图,要求求从起始点到终点的最短路径长度:可以使用dijkstra算法 ...
- HDU 2544 最短路(初涉SPFA算法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 Problem Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t ...
随机推荐
- php构造函数construct用法注意事项
<?php class A { //特别注意,这里的下划线为两个 function __construct() { echo "I am the constructor of A.&l ...
- ubuntu无线上网静态ip配置以及配置静态IP 之后无法正常上网的解决方案
一. 配置无线网络的静态IP 编辑/etc/network/interfaces文件如下: auto lo wlan0 iface lo inet loopback iface wlan0 inet ...
- 单独下载的Qt library则一般不带SSL(包括QT FAQ)
http://www.cnblogs.com/E7868A/archive/2012/11/15/2771501.html http://www.oldcai.com/archives/208 htt ...
- etc/ld.so.conf的使用说明
这个文件记录了编译时使用的动态链接库的路径.默认情况下,编译器只会使用/lib和/usr/lib这两个目录下的库文件如果你安装了某些库,比如在安装gtk+-2.4.13时它会需要glib-2.0 &g ...
- Zookeeper基本知识
Zookeeper的Session: (1)客户端和server间采用长连接 (2)连接建立后,server产生session ID(64位)返还给客户端 (3)客户端定期发送ping包来检查和保持和 ...
- 测试darwin calendar 服务器
cd CalDAVTester README.txt中说的明白—— QUICKSTART Edit the serverinfo.xml file to run the test against yo ...
- 八大Webkit内核浏览器
列举出时下最流行的Webkit内核浏览器,所以我们并不会做出评测和对比.PS:本文列举的浏览器有一部分为IE+Webkit双核浏览器,如果您对其他IE内核浏览器很感兴趣<抛弃数据!用体验和感觉告 ...
- JPA详解
2006 年 5 月 2 日,EJB 3.0 规范最终版由 JCP(Java Community Process) 正式公布,标准号为 JSR(Java Specification Request)2 ...
- awesome cpp
https://github.com/fffaraz/awesome-cpp Awesome C/C++ A curated list of awesome C/C++ frameworks, lib ...
- MediaPlayer和AudioTrack播放Audio的区别与联系
转自http://blog.csdn.net/ameyume/article/details/7618820 播放声音可以用MediaPlayer和AudioTrack,两者都提供了java API供 ...