博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bellman ford优先队列优化简介模板
阅读量:4602 次
发布时间:2019-06-09

本文共 930 字,大约阅读时间需要 3 分钟。

#include<iostream>

#include<cstdio>
#include<utility>
#include<queue>
#include<cstring>
using namespace std;
#define INF 1000000000
int d[20005];
int n,m,a,b,c;
int u[200005];
int v[200005];
int l[200005];
int nxt[200005]; // next[e] 记录e的下一条边的标号
int first[20005]; // first[u] 是u的"第一条" 边的编号
int vis[20005];
int min(int a,int b){
return a<b?a:b;
}
int main(){
cin>>n>>m;
for(int i=0;i<=n;i++)
first[i]=-1;
for(int i=1;i<=m;i++){
scanf("%d%d%d",&u[i],&v[i],&l[i]);
nxt[i]=first[u[i]];
first[u[i]]=i;
}
for(int i=1;i<=n;i++)
d[i]=(i==1?0:INF);
memset(vis, 0, sizeof(vis));
queue<int> q;
q.push(1);
while(!q.empty()){
int x=q.front();
q.pop();
vis[x]=0;
for(int e=first[x];e!=-1;e=nxt[e]){
if(d[v[e]]>d[x]+l[e]){
d[v[e]]=d[x]+l[e];
if(!vis[v[e]]){
vis[v[e]]=1;
q.push(v[e]);

}

}
}
}
for(int i=1;i<=n;i++)
cout<<d[i]<<endl;
return 0;

}

5 7

1 2 2
1 5 10
2 3 3
2 5 7
3 4 4
4 5 5
5 3 6

转载于:https://www.cnblogs.com/13224ACMer/p/4633291.html

你可能感兴趣的文章
Memcache 统计分析!
查看>>
(Python第四天)字符串
查看>>
个人介绍
查看>>
使用python动态特性时,让pycharm自动补全
查看>>
MySQL数据库免安装版配置
查看>>
你必知必会的SQL面试题
查看>>
html5 Canvas绘制时钟以及绘制运动的圆
查看>>
Unity3D热更新之LuaFramework篇[05]--Lua脚本调用c#以及如何在Lua中使用Dotween
查看>>
JavaScript空判断
查看>>
洛谷 P1439 【模板】最长公共子序列(DP,LIS?)
查看>>
python timeit
查看>>
Wireless Network 并查集
查看>>
51nod 1019 逆序数
查看>>
20145202马超《JAVA》预备作业1
查看>>
云推送注意(MSDN链接)
查看>>
IDEA 生成 jar 包
查看>>
加减乘除混合版
查看>>
linux基础6-bash shell编程
查看>>
掌握这几种微服务模式助你成为更出色的工程师
查看>>
为什么很多语言选择在JVM上实现
查看>>