Dijkstra算法与Bellman - Ford算法示例(源自网上大牛的博客)【图论】
题意:题目大意:有N个点,给出从a点到b点的距离,当然a和b是互相可以抵达的,问从1到n的最短距离
poj2387
Description
Farmer John's field has N (2 <= N <= 1000) landmarks in it, uniquely numbered 1..N. Landmark 1 is the barn; the apple tree grove in which Bessie stands all day is landmark N. Cows travel in the field using T (1 <= T <= 2000) bidirectional cow-trails of various lengths between the landmarks. Bessie is not confident of her navigation ability, so she always stays on a trail from its start to its end once she starts it.
Given the trails between the landmarks, determine the minimum distance Bessie must walk to get back to the barn. It is guaranteed that some such route exists.
Input
* Lines 2..T+1: Each line describes a trail as three space-separated integers. The first two integers are the landmarks between which the trail travels. The third integer is the length of the trail, range 1..100.
Output
Sample Input
5 5
1 2 20
2 3 30
3 4 20
4 5 20
1 5 100
Sample Output
90
解法一:(dijkstra算法)(PS:2016.3.22修改自己写的版本)
- #include <iostream>
- #include <cstdio>
- #include <cstring>
- #include <algorithm>
- #define MAX 9999999
- using namespace std ;
- int u , v ,n, dis[1111],vis[1111],ma[1111][1111];
- void dijk()
- {
- int k , mini;
- for(int i = 1 ; i <=v;i++)
- {
- dis[i]=ma[1][i];
- }
- for(int i = 1 ;i<=v;i++)
- {
- mini=MAX;
- for(int j = 1 ; j<=v;j++)
- {
- if(!vis[j]&&dis[j]<mini)
- {
- mini=dis[j];
- k=j;
- }
- }
- vis[k]=1;
- for(int j=1 ;j<=v;j++)
- {
- if(dis[j]>dis[k]+ma[k][j])
- {
- dis[j]=dis[k]+ma[k][j];
- }
- }
- }
- }
- int main()
- {
- while(cin>>u>>v)
- {
- n=0;
- for(int i = 0 ; i <=v;i++)
- {
- for(int j = 0 ; j <=v;j++)
- {
- ma[i][j]=MAX;
- }
- ma[i][i]=0;
- vis[i]=0;
- dis[i]=MAX;
- }
- for(int i = 1 ;i<=u;i++)
- {
- int a , b , len;
- cin>>a>>b>>len;
- n=max(max(n,a),b);
- if(ma[a][b]>len)
- {
- ma[a][b]=ma[b][a]=len;
- }
- }
- dijk();
- printf("%d\n",dis[v]);
- }
- return 0 ;
- }
解法二(Bellman-Ford)
- //*bellman算法:
- #include <iostream>
- #include <cstdio>
- #include <cstring>
- #include <algorithm>
- #define N 2010
- #define MAX 99999999
- using namespace std ;
- struct node{
- int a , b , w ;
- }edge[N];
- int n , m ;
- void bell()
- {
- int i , j ;
- int d[N];
- for(int i =1 ; i<=n;i++)//*距离初始化为无穷;
- {
- d[i]=MAX;
- }
- d[1]=0;//*初始地点为0;
- for(i=1;i<=n;i++)
- {
- for(j=1;j<=m;j++)//*按点-边搜,顺便解决了重边问题;
- {
- if(d[edge[j].a]>d[edge[j].b]+edge[j].w) d[edge[j].a]= d[edge[j].b]+edge[j].w;
- if(d[edge[j].b]>d[edge[j].a]+edge[j].w) d[edge[j].b]= d[edge[j].a]+edge[j].w;
- }
- }
- printf("%d\n",d[n]);
- }
- int main()
- {
- int i , a , b ,c;
- while(cin>>m>>n)
- {
- for(int i =1 ; i<=m;i++)//*结构体存边和权
- {
- cin>>a>>b>>c;
- edge[i].a=a;
- edge[i].b=b;
- edge[i].w=c;
- }
- bell();
- }
- return 0 ;
- }
方法三(Floyd-Warshall):虽然过不去数据,因为太大;但是值得一试;
- #include <iostream>
- #include <stdio.h>
- #include <math.h>
- #include <algorithm>
- #include <cstring>
- #define N 2000
- #define MAX 99999999
- using namespace std ;
- int u , v ;
- int dis[N][N];
- void warsh() {
- int i , j , k ;
- for(k=1; k<=v; k++) {
- for(i=1; i<=v; i++) {
- for(j=1; j<=v; j++) {
- dis[i][j]=min(dis[i][j],dis[k][j]+dis[i][k]);
- }
- }
- }
- }
- int main() {
- cin>>u>>v ;
- int a, b , c ;
- for(int i = 1 ; i <= v ; i++) {
- for(int j = 1 ; j <=v; j++) {
- dis[i][j]=MAX;
- }
- }
- for(int i = 0 ; i < v ; i++) {
- dis[i][i]=0;
- }
- for(int i = 1 ; i <=u ; i++) {
- cin>>a>>b>>c;
- dis[a][b]=dis[b][a]=c;
- }
- warsh();
- cout<<dis[1][v]<<endl;
- return 0 ;
- }
Dijkstra算法与Bellman - Ford算法示例(源自网上大牛的博客)【图论】的更多相关文章
- Bellman - Ford 算法解决最短路径问题
Bellman - Ford 算法: 一:基本算法 对于单源最短路径问题,上一篇文章中介绍了 Dijkstra 算法,但是由于 Dijkstra 算法局限于解决非负权的最短路径问题,对于带负权的图就力 ...
- Bellman—Ford算法思想
---恢复内容开始--- Bellman—Ford算法能在更普遍的情况下(存在负权边)解决单源点最短路径问题.对于给定的带权(有向或无向)图G=(V,E),其源点为s,加权函数w是边集E的映射.对图G ...
- random_shuffle (stl算法)打乱顺序 - 飞不会的日志 - 网易博客
random_shuffle (stl算法)打乱顺序 - 飞不会的日志 - 网易博客 random_shuffle (stl算法)打乱顺序 2012-03-31 10:39:11| 分类: 算法 | ...
- 图论——最短路:Floyd,Dijkstra,Bellman-Ford,SPFA算法及最小环问题
一.Floyd算法 用于计算任意两个节点之间的最短路径. 参考了five20的博客 Floyd算法的基本思想如下:从任意节点A到任意节点B的最短路径不外乎2种可能,1是直接从A到B,2是从A经过若干个 ...
- 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次松弛时,还能 ...
- 算法笔记_070:BellmanFord算法简单介绍(Java)
目录 1 问题描述 2 解决方案 2.1 具体编码 1 问题描述 何为BellmanFord算法? BellmanFord算法功能:给定一个加权连通图,选取一个顶点,称为起点,求取起点到其它所有顶 ...
- 排序算法系列:插入排序算法JAVA版(靠谱、清晰、真实、可用、不罗嗦版)
在网上搜索算法的博客,发现一个比较悲剧的现象非常普遍: 原理讲不清,混乱 啰嗦 图和文对不上 不可用,甚至代码还出错 我总结一个清晰不罗嗦版: 原理: 和选择排序类似的是也分成“已排序”部分,和“未排 ...
- 排序算法系列:快速排序算法JAVA版(靠谱、清晰、真实、可用、不罗嗦版)
在网上搜索算法的博客,发现一个比较悲剧的现象非常普遍: 原理讲不清,混乱 啰嗦 图和文对不上 不可用,甚至代码还出错 为了不误人子弟耽误时间,推荐看一些靠谱的资源,如[啊哈!算法]系列: https: ...
随机推荐
- eclipse的maven项目中找不到Maven Dependencies
菜菜的我又来了,笨鸟不一定要先飞,但一定要坚持 今天记录一个初级错误 比如我们在eclipse创建maven项目来运行我们的web项目 搭建完工程后发现javax-servlet包全部报错 到这里我还 ...
- yii2 源码分析Event类分析 (三)
转载请注明链接:http://www.cnblogs.com/liuwanqiu/p/6739880.html Event是所有事件的基类,它继承Object类 Event类上面的注释的大致意思: * ...
- 用mount挂载远程服务器网络硬盘
环境: 服务器:192.168.20.204 客户端:192.168.20.203 1. 在服务器配置/etc/export 添加可以共享的文件夹和允许的客户端地址 /home/dir 192.16 ...
- 阿里云CentOS使用iptables禁止某IP访问
在CentOS下封停IP,有封杀网段和封杀单个IP两种形式.一般来说,现在的攻击者不会使用一个网段的IP来攻击(太招摇了),IP一般都是散列的.于是下面就详细说明一下封杀单个IP的命令,和解封单个IP ...
- ABP框架源码学习之授权逻辑
asp.net core的默认的几种授权方法参考"雨夜朦胧"的系列博客,这里要强调的是asp.net core mvc中的授权和asp.net mvc中的授权不一样,建议先看前面& ...
- Jenkins +git +python 进行持续集成进行接口测试(接口测试jenkins持续集成篇)
使用jenkins+git+python脚本进行持续集成的接口测试,在jenkins平台,利用插件等,把管理代码的git仓库的代码更新下来进行持续接口测试,python进行开发测试脚本,git进行远程 ...
- XAMPP环境访问非Web DocumentRoot下绝对路径
假设你的XAMPP网站文档根目录在C:/xampp/apache/htdocs/下面,那么访问这个目录下的文件是很直接的. 但是有时候需要把用户上传文件指定到特殊目录,比如E盘,那么就需要用户能够访问 ...
- Python自动化--语言基础3--字典、函数、全局/局部变量
字典 dict1 = {'name':'han','age':18,'class':'first'} print(dict1.keys()) #打印所有的key值 print(dict1.values ...
- eclipse快捷注释生成方法
自动生成方法的注释格式,例如 /*** @param str* @return* @throws ParseException*/ 快捷键是alt+shift+j,将光标放在方法名上,按快捷键.会生成 ...
- [翻译] 编写高性能 .NET 代码--第二章 GC -- 将长生命周期对象和大对象池化
将长生命周期对象和大对象池化 请记住最开始说的原则:对象要么立即回收要么一直存在.它们要么在0代被回收,要么在2代里一直存在.有些对象本质是静态的,生命周期从它们被创建开始,到程序停止才会结束.其它对 ...