您的位置:首页 > 其它

HDU 2544 最短路 (最短路,spfa)

2015-06-30 20:32 423 查看
题意:中文题目

思路: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代码
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: