Bellman-Ford算法
#include<stdio.h>
#define max 0xffffff
int g[][]; //图的邻接矩阵
int dist[];
int n;//顶点个数
int m;//边个数
struct Edge
{
int u, v, w; //边:起点、终点、权值
};
Edge e[];
bool bellman_ford(int n)//bellman-ford算法
{
int i, k, t,j;
for(i=;i<n;i++)
dist[i]=g[][i];//初始化
for(i=;i<=n-;i++)
{ /*假设第k条边的起点是u,终点是v,以下循环考虑第k条边是否会使得源点v0到v的
最短距离缩短,即判断dist[edges[k].u] + edges[k].w < dist[edges[k].v] 是否成立*/
for(j=;j<n;j++)
{
printf("%d ",dist[j]);
}
printf("\n");
for(k=;k<=m;k++)
{
t=dist[e[k].u]+e[k].w;
if(dist[e[k].u]<max&&t<dist[e[k].v])
{
dist[e[k].v] = t;
}
}
}
/*以下是检查,若还有更新则说明存在无限循环的负值回路*/
for(k = ; k < m; k ++)
{
if(dist[e[k].u] != max &&dist[e[k].u] + e[k].w < dist[e[k].v])
{
return false;
}
}
return true;
} int main()
{
scanf("%d %d",&n,&m);
int i,j;
for(i=;i<n;i++)
{
for(j=;j<n;j++)
g[i][j]=max;
g[i][i]=;
}
for(i=;i<=m;i++)
{
int a,b,c;
scanf("%d %d %d",&a,&b,&c);
e[i].u=a;
e[i].v=b;
e[i].w=c;
g[a][b]=c;
}
for(i=;i<n;i++)
{
for(j=;j<n;j++)
printf("%d ",g[i][j]);
printf("\n");
}
bellman_ford(n);
for(i=;i<n;i++)
{
printf("%d\n",dist[i]);
} return ;
} /* 7 10
0 1 6
0 2 5
0 3 5
1 4 -1
2 1 -2
2 4 1
3 2 -2
3 5 -1
4 6 3
5 6 3 Press any key to continue */
……
递推公式(求顶点u到源点v的最短路径):
dist 1 [u] = Edge[v][u]
dist k [u] = min{ dist k-1 [u], min{ dist k-1 [j] + Edge[j][u] } }, j=0,1,…,n-1,j≠u
struct Edge
{
int u, v, w; //边:起点、终点、权值
};
Edge e[];
void bellman_ford(int n)//bellman-ford算法
{
int i, k, t;
for(i=;i<=n;i++)
dist[i]=g[][i];//初始化
for(i=;i<=n;i++)
{
for(k=;k<=m;k++)
{
t=dist[e[k].u]+e[k].w;
if(dist[e[k].u]<max&&t<dist[e[k].v])
{
dist[e[k].v] = t;
}
}
}
}

#include<stdio.h>
#define max 0xffffff
int g[][]; //图的邻接矩阵
int dist[];
int n;//顶点个数
int m;//边个数
struct Edge
{
int u, v, w; //边:起点、终点、权值
};
Edge e[];
bool bellman_ford(int n)//bellman-ford算法
{
int i, k, t,j;
for(i=;i<n;i++)
dist[i]=g[][i];//初始化
for(i=;i<=n-;i++)
{ /*假设第k条边的起点是u,终点是v,以下循环考虑第k条边是否会使得源点v0到v的
最短距离缩短,即判断dist[edges[k].u] + edges[k].w < dist[edges[k].v] 是否成立*/
for(j=;j<n;j++)
{
printf("%d ",dist[j]);
}
printf("\n");
for(k=;k<=m;k++)
{
t=dist[e[k].u]+e[k].w;
if(dist[e[k].u]<max&&t<dist[e[k].v])
{
dist[e[k].v] = t;
}
}
}
/*以下是检查,若还有更新则说明存在无限循环的负值回路*/
for(k = ; k < m; k ++)
{
if(dist[e[k].u] != max &&dist[e[k].u] + e[k].w < dist[e[k].v])
{
return false;
}
}
return true;
} int main()
{
scanf("%d %d",&n,&m);
int i,j;
for(i=;i<n;i++)
{
for(j=;j<n;j++)
g[i][j]=max;
g[i][i]=;
}
for(i=;i<=m;i++)
{
int a,b,c;
scanf("%d %d %d",&a,&b,&c);
e[i].u=a;
e[i].v=b;
e[i].w=c;
g[a][b]=c;
}
for(i=;i<n;i++)
{
for(j=;j<n;j++)
printf("%d ",g[i][j]);
printf("\n");
}
bellman_ford(n);
for(i=;i<n;i++)
{
printf("%d\n",dist[i]);
} return ;
} /* 7 10
0 1 6
0 2 5
0 3 5
1 4 -1
2 1 -2
2 4 1
3 2 -2
3 5 -1
4 6 3
5 6 3 Press any key to continue */
void bellman_ford(int n)//bellman-ford算法
{
int i, k, t,j;
for(i=;i<=n;i++)
dist[i]=g[][i];//初始化
for(k=;k<=n;k++)
{
for(j=;j<=n;j++)
{
for(i=;i<=n;i++)
{
if(g[i][j]<max&&dist[i]+g[i][j]<dist[j])
dist[j]=dist[i]+g[i][j];
}
}
}
}
Bellman-Ford算法的更多相关文章
- Bellman—Ford算法思想
---恢复内容开始--- Bellman—Ford算法能在更普遍的情况下(存在负权边)解决单源点最短路径问题.对于给定的带权(有向或无向)图G=(V,E),其源点为s,加权函数w是边集E的映射.对图G ...
- Bellman - Ford 算法解决最短路径问题
Bellman - Ford 算法: 一:基本算法 对于单源最短路径问题,上一篇文章中介绍了 Dijkstra 算法,但是由于 Dijkstra 算法局限于解决非负权的最短路径问题,对于带负权的图就力 ...
- Dijkstra算法与Bellman - Ford算法示例(源自网上大牛的博客)【图论】
题意:题目大意:有N个点,给出从a点到b点的距离,当然a和b是互相可以抵达的,问从1到n的最短距离 poj2387 Description Bessie is out in the field and ...
- poj1860 bellman—ford队列优化 Currency Exchange
Currency Exchange Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 22123 Accepted: 799 ...
- uva 558 - Wormholes(Bellman Ford判断负环)
题目链接:558 - Wormholes 题目大意:给出n和m,表示有n个点,然后给出m条边,然后判断给出的有向图中是否存在负环. 解题思路:利用Bellman Ford算法,若进行第n次松弛时,还能 ...
- ACM/ICPC 之 最短路径-Bellman Ford范例(POJ1556-POJ2240)
两道Bellman Ford解最短路的范例,Bellman Ford只是一种最短路的方法,两道都可以用dijkstra, SPFA做. Bellman Ford解法是将每条边遍历一次,遍历一次所有边可 ...
- 图论算法——最短路径Dijkstra,Floyd,Bellman Ford
算法名称 适用范围 算法过程 Dijkstra 无负权 从s开始,选择尚未完成的点中,distance最小的点,对其所有边进行松弛:直到所有结点都已完成 Bellman-Ford 可用有负权 依次对所 ...
- POJ 2240 Arbitrage (Bellman Ford判正环)
Arbitrage Time Limit: 1000MS Memory Limit: 65536K Total Submissions:27167 Accepted: 11440 Descri ...
- poj1860 兑换货币(bellman ford判断正环)
传送门:点击打开链接 题目大意:一个城市有n种货币,m个货币交换点,你有v的钱,每个交换点只能交换两种货币,(A换B或者B换A),每一次交换都有独特的汇率和手续费,问你存不存在一种换法使原来的钱更多. ...
- ACM/ICPC 之 Bellman Ford练习题(ZOJ1791(POJ1613))
这道题稍复杂一些,需要掌握字符串输入的处理+限制了可以行走的时间. ZOJ1791(POJ1613)-Cave Raider //限制行走时间的最短路 //POJ1613-ZOJ1791 //Time ...
随机推荐
- 四则运算 Day1
需求分析 1.N(Need,需求) 该软件用户只有一类角色:小学生 要求能根据用户选择的算法(+-/),产生随机数(在0--10之间的整数)进行该算法的计算,程序能接收用户输入的答案,如果用户输入的为 ...
- java设计优化--观察者模式
观察者模式介绍 观察者模式是一种非常有用的设计模式,在软件系统中,当一个对象的行为依赖于另一个对象的状态时,观察者模式就非常有用.如果不适用观察者模式,而实现类似的功能,可能就需要另外启动一个线程不停 ...
- js常用插件
1.jQuery Shortcuts 是个超轻量级的方法,使用 jQuery 来绑定快捷键(热键). 2.Underscore封装了常用的JavaScript对象操作方法,用于提高开发效率. 3.Kn ...
- 【kAri OJ 616】Asce的树
时间限制 1000 ms 内存限制 65536 KB 题目描述 作为一个东北大老爷们,大A熊以力气大著称,现在有一颗半径为r的树,剖面图如黑色的圆,大A熊决定搬几个半径为R的圆柱形桶将其围住,剖面图如 ...
- 【HDU 2604】Queuing
题 题意 f和m两种字母组成字符串,fmf 和 fff 这种为不安全的字符串,现在有2*L个字母,问你有多少安全的字符串.答案mod M. 分析 递推,这题本意是要用矩阵快速幂.不过我发现这题好神奇, ...
- Linux Communication Mechanism Summarize
目录 . Linux通信机制分类简介 . 控制机制 0x1: 竞态条件 0x2: 临界区 . Inter-Process Communication (IPC) mechanisms: 进程间通信机制 ...
- Linux Rootkit Learning
目录 . 学习Rootkit需要了解的基础知识 . 挂钩(HOOKING) . 直接内核对象操作 . LSM框架(Linux Security Module)于LKM安全 . rootkit检测技术及 ...
- C#图片读取和保存
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- eclipse下载
http://www.eclipse.org/downloads/eclipse-packages
- mysql 外键(FOREIGN KEY)
最近有开始做一个实验室管理系统,因为分了几个表进行存储·所以要维护表间的关联··研究了一下MySQL的外键. (1)只有InnoDB类型的表才可以使用外键,mysql默认是MyISAM,这种类型不支持 ...