最短路 模板 【bellman-ford,dijkstra,floyd-warshall】
Bellman-ford:
/*
bellman ford
*/
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int INF = 0x3f3f3f3f;
const int Max = 9999;
typedef struct edge{
int from,to;
int ed;
}Edge;
Edge edge[100];
int v[Max];
int d[Max];
int V,E;
void bellman_ford(int s)
{
memset(d,0x3f,sizeof(d));
d[s]=0;
while(true){//如果不存在负圈,最多执行|V|-1次
bool update = false;
for(int i=0;i<E;i++){
Edge e = edge[i];
if(d[e.from]!=INF&&d[e.to]>d[e.from]+e.ed){
d[e.to]=d[e.from]+e.ed;
update = true;
}
}
if(!update) break;
}
}
bool find_negative_loop()
{
memset(d,0,sizeof(d));
for(int i=0;i<V;i++)
for(int j=0;j<E;j++){
Edge e = edge[j];
if(d[e.to]>d[e.from]+e.ed){
d[e.to] = d[e.from]+e.ed;
if(i==V-1) return true;
}
}
return false;
}
int main()
{
int s,e;
scanf("%d%d",&V,&E);
for(int i=0;i<V;i++)
scanf("%d",&v[i]);
for(int i=0;i<E;i++)
scanf("%d%d%d",&edge[i].from,&edge[i].to,&edge[i].ed);
if(find_negative_loop()) printf("yes\n");
else printf("no\n");
return 0;
}
floyd-warshall:
/*
floyd-warshall
*/
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int INF = 0x3f3f3f3f;
const int Max = 200;
int d[Max][Max];
int V,E;
bool floyd_warshall()
{
for(int k=1;k<=V;k++){
for(int i=1;i<=V;i++){
for(int j=1;j<=V;j++){
d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
}
}
}
for(int i=1;i<=V;i++)
if(d[i][i]<0){
return false;
}
return true;
}
int main()
{
freopen("input.txt","r",stdin);
scanf("%d%d",&V,&E);
for(int i=1;i<=V;i++)
for(int j=1;j<=V;j++)
d[i][j]=d[j][i] = (i==j?0:INF);
for(int i=0;i<E;i++)
{
int from,to,cost;
scanf("%d%d%d",&from,&to,&cost);
d[from][to]=d[to][from]=cost;
}
if(floyd_warshall()) printf("%d\n",d[1][V]);
else printf("负圈\n");
return 0;
}
dijkstra:
邻接矩阵实现
/*
dijkstra1
*/
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
const int Max = 200;
const int INF = 0x3f3f3f3f;
int d[Max];
int vis[Max];
int cost[Max][Max];
int V,E;
void dijkstra(int s)
{
memset(d,0x3f,sizeof(d));
memset(vis,0,sizeof(vis));
d[s]=0;
while(1){
int v = -1;
for(int u=1;u<=V;u++){
if(!vis[u]&&(v==-1||d[u]<d[v]))
v = u;
}
if(v==-1) break;
vis[v]=1;
for(int u=1;u<=V;u++){
d[u]=min(d[u],d[v]+cost[v][u]);
}
}
}
int main()
{
//freopen("input.txt","r",stdin);
int from,to,co;
cin>>V>>E;
for(int i=1;i<=V;i++)
for(int j=1;j<=V;j++)
cost[i][j]=INF;
for(int i=0;i<E;i++)
{
cin>>from>>to;
cin>>cost[from][to];
}
int s,en;
cin>>s>>en;
dijkstra(s);
cout<<d[en]<<endl;
return 0;
}
void dijkstra()
{
memset(dis,0x3f,sizeof(dis));
memset(vis,0,sizeof(vis));
dis[1]=0;
for(int i=1;i<=V;i++)
{
int mi = INF,k;
for(int j=1;j<=V;j++){
if(vis[j]==0&&dis[j]<mi){
mi = dis[j];
k = j;
}
}//找最小
vis[k]=1;
for(int j=1;j<=V;j++)
dis[j]=min(dis[j],dis[k]+mp[k][j]);
}
}
优先队列实现:
/*
dijkstra2
*/
#include <iostream>
#include <cstdio>
#include <vector>
#include <queue>
#include <cstring>
using namespace std;
const int INF = 0x3f3f3f3f;
const int Max = 200;
typedef pair<int,int> P;
typedef struct Edge{
int v,cost;
};
Edge edge[Max];
vector<Edge> G[Max];
int d[Max];
int V,E;
void dijkstra(int s)
{
memset(d,0x3f,sizeof(d));
d[s]=0;
priority_queue<P ,vector<P>,greater<P> > que;
que.push(P(0,s));
while(!que.empty()){
P top = que.top();que.pop();
int u = top.second;
if(d[u]<top.first) continue;
for(int i=0;i<G[u].size();i++){
Edge e = G[u][i];
if(d[e.v]>d[u]+e.cost){
d[e.v]=d[u]+e.cost;
que.push(P(d[e.v],e.v));
}
}
}
}
int main()
{
cin>>V>>E;
for(int i=0;i<E;i++){
int u;
cin>>u>>edge[i].v>>edge[i].cost;
G[u].push_back(edge[i]);
}
int s,e;
cin>>s>>e;
dijkstra(s);
printf("s->e:%d\n",d[e]);
return 0;
}
路径还原:
memset(pre,-1,sizeof(pre));
…………………………
pre[v]=now;
…………………………
vector<int> path;
int tmp = t;
while(tmp!=-1){
path.push_back(tmp);
tmp = pre[tmp];
}
for(int i=path.size()-1;i>=0;i--)
if(i==0) printf("%d ",path[i]);
else printf("%d -> ",path[i]);
最短路 模板 【bellman-ford,dijkstra,floyd-warshall】的更多相关文章
- 最短路模板|堆优化Dijkstra,SPFA,floyd
Ⅰ:Dijkstra单源点最短路 1.1Dijkstra const int MAX_N = 10000; const int MAX_M = 100000; const int inf = 0x3f ...
- 关于SPFA Bellman-Ford Dijkstra Floyd BFS最短路的共同点与区别
关于模板什么的还有算法的具体介绍 戳我 这里我们只做所有最短路的具体分析. 那么同是求解最短路,这些算法到底有什么区别和联系: 对于BFS来说,他没有松弛操作,他的理论思想是从每一点做树形便利,那么时 ...
- 最短路问题(Bellman/Dijkstra/Floyd)
最短路问题(Bellman/Dijkstra/Floyd) 寒假了,继续学习停滞了许久的算法.接着从图论开始看起,之前觉得超级难的最短路问题,经过两天的苦读,终于算是有所收获.把自己的理解记录下来,可 ...
- ACM-最短路(SPFA,Dijkstra,Floyd)之最短路——hdu2544
***************************************转载请注明出处:http://blog.csdn.net/lttree************************** ...
- 图论之最短路径(1)——Floyd Warshall & Dijkstra算法
开始图论学习的第二部分:最短路径. 由于知识储备还不充足,暂时不使用邻接表的方法来计算. 最短路径主要分为两部分:多源最短路径和单源最短路径问题 多源最短路径: 介绍最简单的Floyd Warshal ...
- ACM/ICPC 之 最短路径-Bellman Ford范例(POJ1556-POJ2240)
两道Bellman Ford解最短路的范例,Bellman Ford只是一种最短路的方法,两道都可以用dijkstra, SPFA做. Bellman Ford解法是将每条边遍历一次,遍历一次所有边可 ...
- POJ-图论-最短路模板(邻接矩阵)
POJ-图论-最短路模板 一.Floyd算法 刚读入数据时,G为读入的图邻接矩阵,更新后,G[i][j]表示结点i到结点j的最短路径长度 int G[N][N];//二维数组,其初始值即为该图的邻接矩 ...
- 最短路径-Dijkstra+Floyd+Spfa
Dijkstra算法: Dijkstra(迪杰斯特拉)算法是典型的单源最短路径算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层层扩展,直到扩展到终点为止.Dijkstra ...
- poj1511/zoj2008 Invitation Cards(最短路模板题)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud Invitation Cards Time Limit: 5 Seconds ...
随机推荐
- javascript 高级程序设计 五
1.变量: ECMAScript中的基本类型都是值类型Boolean,Number,Null,Undefined和String,在这里JS和其他的语言有所不同,就是JS中的String是值类型 而不像 ...
- sleep()方法和yield()方法有什么区别?
两者都是Thread类的静态方法,定义如下 public static void sleep(long millis) throws InterruptedException public stati ...
- BS架构如何实现即时消息提醒
转载地址:https://blog.csdn.net/cyjch/article/details/51506434
- python之排列组合测试
# test permutations and combinations import itertools as it for i in it.combinations('abcd',2): prin ...
- 【密码学】轻松理解“加盐”的原理与java实现
转自:https://blog.csdn.net/DavidHuang2017/article/details/80283469 一.什么是加盐? 1.背景 现在很多公司后台以hash值形式存储用户密 ...
- usart下位机输出使用printf的格式化技巧
输出使用printf("0x%3X ", I2c_Buf_Write[i]);时,上位机接收过程,使用文本格式,显示结果如下 虽然是保留了三位的宽度,但是并不美观. 相比于使用pr ...
- 47.iOS跳转AppStore评分和发送邮件
1.跳转到AppStore评分 应用地址是关键:IOS 设备,手机搜索应用,拷贝链接 NSString *appStr =@"https://itunes.apple.com/cn/app/ ...
- idea运行项目时报Error:java无效的源发行版:1.8
如果你安装的是JDK1.7,而在file->project structure中设置的是language level是8的话,就会出现这个错误提示:无效的源发行版:8. 解决办法:将语言级别改为 ...
- ELASTIC SEARCH 性能调优
ELASTICSEARCH 性能调优建议 创建索引调优 1.在创建索引的使用使用批量的方式导入到ES. 2.使用多线程的方式导入数据库. 3.增加默认刷新时间. 默认的刷新时间是1秒钟,这样会产生太多 ...
- 哪些优秀的 Windows 小工具,类似 clover 或 everything
有哪些优秀的 Windows 小工具,类似 clover 或 everything? 目前已知的有everything, listary, total commander, clover, dexpo ...