HDU 2544 最短路 (最短路,spfa)
2015-06-30 20:32
423 查看
题意:中文题目
思路:spfa+SLF优化。关于SPFA的详情请戳我
AC代码
思路:spfa+SLF优化。关于SPFA的详情请戳我
#include <bits/stdc++.h> #define LL long long using namespace std; const int N=100+5; const int INF=0x7f7f7f7f; int g ; int vis ; int dist ; int dijkstra(int n) { memset(vis,0,sizeof(vis)); memset(dist,0x7f,sizeof(dist)); dist[1]=0; for(int i=1; i<=n; i++) //每次用1个点来更新到其他点的距离 { int flag, small=INF; for(int j=1; j<=n; j++)//找距离最小的点 { if(!vis[j]&&dist[j]<=small) { small=dist[j]; flag=j; } } vis[flag]=1;//标记,不需要再用其更新别人。 for(int j=1; j<=n; j++)//有边相连就得更新 { if(g[j][flag]) dist[j]=min(dist[flag]+g[flag][j], dist[j]); } } return dist ; } int main() { freopen("input.txt", "r", stdin); int n, m, a, b, w; while(scanf("%d%d",&n, &m), n+m) { memset(g,0,sizeof(g)); for(int i=0; i<m; i++) { scanf("%d%d%d",&a,&b,&w); g[a][b]=g[b][a]=w; } cout<<dijkstra(n)<<endl; } return 0; }
AC代码
相关文章推荐
- vector中erase用法注意事项
- ZOJ Problem Set - 2482||IP Address
- 使用aapt查看apk包名和第一个启动的activity
- Matlab与微积分计算
- TCP连接与关闭
- 黑马程序员——java的IO之流操作的基本规律,Properties类,打印流,序列流
- ZOJ Problem Set - 1414||Number Steps
- 黑马day11 脏读数据&解决方案
- LeetCode Sort Colors
- makeBackronym
- 数据库复习9——关系代数和关系演算
- 如何在VIM中保存编辑的只读文件
- REST与SOAP之比较——SOAP篇
- matlab注意事项
- Packet Tracer 6.2新特性
- CSS float属性小解——”浮“生若水
- android模拟器网络设置(局域网)
- Xcode真机调试报错:The application could not be verified.
- 背景音乐功能
- leetcode--217&219&220 Contains Duplicate(重复)I&II&III