单源最短路模板 + hdu - 2544
Floyd
Floyd 本质上类似一种动态规划,dp [ i ] [ j ] = dp [ i ] [ k ] + dp[ k ] [ j ]。
/**
* Night gathers, and now my watch begins.
* It shall not end until my death.
* I shall take no wife, hold no lands, father no children.
* I shall wear no crowns and win no glory.
* I shall live and die at my post.
* I am the sword in the darkness.
* I am the watcher on the walls.
* I am the fire that burns against the cold,
* the light that wakes the sleepers,
* the shield that guards the realms of men.
* I pledge my life and honor to the Night's Watch,
* for this night,
* and all the nights to come.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
;
;
;
;
using namespace std;
int Map[MAXN][MAXN];
int n, m, q;
int a, b, c;
void Floyd () {
; k < n; k++)
; i <= n; i++)
; j <= n; j++)
Map[i][j] = min (Map[i][j], Map[i][k] + Map[k][j]);
}
int main() {
while (cin >> n >> m >> q) {
; i <= n; i++)
; j <= n; j++)
Map[i][j] = INF;
; i <= m; i++) {
cin >> a >> b >> c;
Map[a][b] = Map[b][a] = min (Map[a][b], c);
}
Floyd();
; i <= q; i++) {
cin >> a >> b;
cout << Map[a][b] << endl;
}
}
;
}
Floyd
/**
* Night gathers, and now my watch begins.
* It shall not end until my death.
* I shall take no wife, hold no lands, father no children.
* I shall wear no crowns and win no glory.
* I shall live and die at my post.
* I am the sword in the darkness.
* I am the watcher on the walls.
* I am the fire that burns against the cold,
* the light that wakes the sleepers,
* the shield that guards the realms of men.
* I pledge my life and honor to the Night's Watch,
* for this night,
* and all the nights to come.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
;
;
;
;
using namespace std;
int Map[MAXN][MAXN];
int n, m, q;
int a, b, c;
void Floyd () {
; k <= n; k++)
; i <= n; i++)
; j <= n; j++)
Map[i][j] = min (Map[i][j], Map[i][k] + Map[k][j]);
}
int main() {
while (~scanf ("%d%d", &n, &m) && n || m) {
; i <= n; i++)
; j <= n; j++)
Map[i][j] = INF;
; i <= m; i++) {
scanf ("%d%d%d", &a, &b, &c);
Map[a][b] = Map[b][a] = min (Map[a][b], c);
}
Floyd();
cout << Map[][n] << endl;
}
;
}
Dijkstra
从源点出发,首先寻找离源点最近的几个节点,now 储存现在离源点最近的节点的序号。
/**
* Night gathers, and now my watch begins.
* It shall not end until my death.
* I shall take no wife, hold no lands, father no children.
* I shall wear no crowns and win no glory.
* I shall live and die at my post.
* I am the sword in the darkness.
* I am the watcher on the walls.
* I am the fire that burns against the cold,
* the light that wakes the sleepers,
* the shield that guards the realms of men.
* I pledge my life and honor to the Night's Watch,
* for this night,
* and all the nights to come.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
;
;
;
;
using namespace std;
int Map[MAXN][MAXN];
int dis[MAXN];
int vis[MAXN];
int n, m, q;
int a, b, c;
void Dijkstra (int src) {
mem (vis, );
; i <= n; i++)
dis[i] = INF;
dis[src] = ;
) {
;
; i <= n; i++)
|| dis[i] < dis[now]))
now = i;
)
break;
vis[now] = ;
; i <= n; i++)
dis[i] = min (dis[i], dis[now] + Map[now][i]);
cout<<now<<endl;
; i <= n; i++)
cout << dis[i] << ' ';
cout << endl;
}
}
int main() {
while (cin >> n >> m >> q) {
; i <= n; i++)
; j <= n; j++)
Map[i][j] = INF;
; i <= m; i++) {
cin >> a >> b >> c;
Map[a][b] = Map[b][a] = min (Map[a][b], c);
}
Dijkstra ();
; i <= q; i++) {
cin >> a >> b;
cout << dis[i] << endl;
}
}
;
}
Dijkstra
/**
* Night gathers, and now my watch begins.
* It shall not end until my death.
* I shall take no wife, hold no lands, father no children.
* I shall wear no crowns and win no glory.
* I shall live and die at my post.
* I am the sword in the darkness.
* I am the watcher on the walls.
* I am the fire that burns against the cold,
* the light that wakes the sleepers,
* the shield that guards the realms of men.
* I pledge my life and honor to the Night's Watch,
* for this night,
* and all the nights to come.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
;
;
;
;
using namespace std;
int Map[MAXN][MAXN];
int dis[MAXN];
int vis[MAXN];
int n, m, q;
int a, b, c;
void Dijkstra (int src) {
mem (vis, );
; i <= n; i++)
dis[i] = INF;
dis[src] = ;
) {
;
; i <= n; i++)
|| dis[i] < dis[now]))
now = i;
)
break;
vis[now] = ;
; i <= n; i++)
dis[i] = min (dis[i], dis[now] + Map[now][i]);
cout<<now<<endl;
; i <= n; i++)
cout << dis[i] << ' ';
cout << endl;
}
}
int main() {
while (cin >> n >> m >> q) {
; i <= n; i++)
; j <= n; j++)
Map[i][j] = INF;
; i <= m; i++) {
cin >> a >> b >> c;
Map[a][b] = Map[b][a] = min (Map[a][b], c);
}
Dijkstra ();
; i <= q; i++) {
cin >> a >> b;
cout << dis[i] << endl;
}
}
;
}
SPFA
将每次被松弛了的节点入队,直到队列为空,得到的就是源点到各节点的最短路。
/**
* Night gathers, and now my watch begins.
* It shall not end until my death.
* I shall take no wife, hold no lands, father no children.
* I shall wear no crowns and win no glory.
* I shall live and die at my post.
* I am the sword in the darkness.
* I am the watcher on the walls.
* I am the fire that burns against the cold,
* the light that wakes the sleepers,
* the shield that guards the realms of men.
* I pledge my life and honor to the Night's Watch,
* for this night,
* and all the nights to come.
*/
#include<bits/stdc++.h>
#define lson i<<2
#define rson i<<2|1
#define LS l,mid,lson
#define RS mid+1,r,rson
#define mem(a,x) memset(a,x,sizeof(a))
#define gcd(a,b) __gcd(a,b)
#define ll long long
#define ull unsigned long long
#define lowbit(x) (x&-x)
#define enld endl
#define mian main
#define itn int
#define prinft printf
const double PI = acos (-1.0);
const int INF = 0x3f3f3f3f;
;
;
;
;
using namespace std;
//邻接表实现
struct node {
int to, cost;
node (int a, int b) {
to = a, cost = b;
}
};
vector<node> edge[MAXN];
int vis[MAXN]; //可以用map
int dis[MAXN];
int n, m;
int a, b, c;
queue<int> q;
void spfa (int src) {
mem (vis, );
vis[src] = ;
dis[src] = ;
q.push (src);
while (!q.empty()) {
int now = q.front();
q.pop();
vis[now] = ;
; i < edge[now].size(); ++i) {
if (dis[now] + edge[now][i].cost > dis[edge[now][i].to])
continue;
dis[edge[now][i].to] = dis[now] + edge[now][i].cost; //更新
if (!vis[edge[now][i].to]) { //入队
q.push (edge[now][i].to);
vis[edge[now][i].to] = ;
}
}
}
}
int main() {
while (cin >> n >> m && (n || m)) {
while (!q.empty())
q.pop();
; i <= n; i++)
dis[i] = INF;
; i <= n; i++)
edge[i].clear();
; i <= m; i++) {
cin >> a >> b >> c;
edge[a].push_back (node (b, c)), edge[b].push_back (node (a, c));
}
spfa ();
cout << dis[n] << endl;
}
;
}
hdu 2544 SPFA
单源最短路模板 + hdu - 2544的更多相关文章
- 单源最短路模板(dijkstra)
单源最短路(dijkstra算法及堆优化) 弱化版题目链接 n^2 dijkstra模板 #include<iostream> #include<cstdio> #includ ...
- 单源最短路模板_SPFA_Dijkstra(堆优化)_C++
随手一打就是标准的SPFA,默认1号节点为出发点,当然不用 f 判断是否在队里也可以,只是这样更优化一点 void spfa() { int i,x,k; ;i<=n;i++) { d[i]=o ...
- 【单源最短路模板】 poj 2387
#include <cstdio> #include <iostream> #include <stdlib.h> #include <memory.h> ...
- 最短路模板(Dijkstra & Dijkstra算法+堆优化 & bellman_ford & 单源最短路SPFA)
关于几个的区别和联系:http://www.cnblogs.com/zswbky/p/5432353.html d.每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个(草儿家到 ...
- [ACM_图论] Domino Effect (POJ1135 Dijkstra算法 SSSP 单源最短路算法 中等 模板)
Description Did you know that you can use domino bones for other things besides playing Dominoes? Ta ...
- 模板C++ 03图论算法 1最短路之单源最短路(SPFA)
3.1最短路之单源最短路(SPFA) 松弛:常听人说松弛,一直不懂,后来明白其实就是更新某点到源点最短距离. 邻接表:表示与一个点联通的所有路. 如果从一个点沿着某条路径出发,又回到了自己,而且所经过 ...
- 单源最短路_SPFA_C++
当我们需要求一个点到其它所有点的最短路时,我们可以采用SPFA算法 代码特别好写,而且可以有环,但是不能有负权环,时间复杂度是O(α(n)n),n为边数,α(n)为n的反阿克曼函数,一般小于等于4 模 ...
- 2018/1/28 每日一学 单源最短路的SPFA算法以及其他三大最短路算法比较总结
刚刚AC的pj普及组第四题就是一种单源最短路. 我们知道当一个图存在负权边时像Dijkstra等算法便无法实现: 而Bellman-Ford算法的复杂度又过高O(V*E),SPFA算法便派上用场了. ...
- 用scheme语言实现SPFA算法(单源最短路)
最近自己陷入了很长时间的学习和思考之中,突然发现好久没有更新博文了,于是便想更新一篇. 这篇文章是我之前程序设计语言课作业中一段代码,用scheme语言实现单源最段路算法.当时的我,花了一整天时间,学 ...
随机推荐
- Spring 学习01
一.Spring概念 1 spring是开源的轻量级框架 2 spring核心主要两部分: (1)aop:面向切面编程,扩展功能不是修改源代码实现 (2)ioc:控制反转, - 比如有一个类,在类里面 ...
- Ajax和jsonp区别
大多数情况下,无论是框架还是自己实现都是通过Ajax的方式来向后端请求数据的,而Ajax之间是通过传输json格式的文件来进行数据的传输的,大家对Ajax也很熟悉了,那么为什么我又要使用jsonp呢? ...
- vue需要注意的事宜
1.Vue在进行点击事件的时候大部分是在标签上进行添加的,一般在标签上添加@click: 如果需要在组件上面进行点击事件的时候,直接写@click是木有变化的,需要在后面添加一个.native就如@c ...
- java Socket和ServerSocket多线程编程
这是在一本java教材上看到的,做了点修改.具体本教材记不清楚了,Sorry.放在这里,只是让自己需要的时候能够容易找到. 程序分两部分,服务端和客户端.先把服务端运行起来,在运行客户端.整个过程就是 ...
- mysql 字符编码设置
安装mysql时如果字符编码为默认值latin1,则需要修改为utf8以便支持中文数据. 命令如下: 1.显示数据库字符集 mysql> show create database test;+- ...
- [golang note] 环境搭建
LiteIDE(windows) • golang安装 ▶ 下载对应操作系统的版本并安装,下载地址:http://www.golangtc.com/download,譬如这里下载的是go1.6.win ...
- 交换机NTP的MD5配置
1.ntp-service authentication enable 开启NTP身份验证功能 2.ntp-service source-interfer LoopBack0 指定本机发生NTP的端 ...
- InnoDB逻辑存储结构
从InnoDB存储引擎的逻辑存储结构看,所有数据都被逻辑地存放在一个空间中,称之为表空间(tablespace).表空间又由段(segment).区(extent).页(page)组成.页在一些文档中 ...
- Zookeeper集群搭建以及python操作zk
一.Zookeeper原理简介 ZooKeeper是一个开放源码的分布式应用程序协调服务,它包含一个简单的原语集,分布式应用程序可以基于它实现同步服务,配置维护和命名服务等. Zookeeper设计目 ...
- ADO.Net练习1
一. 1.Car表数据查出显示2.请输入要查的汽车名称: 请输入要查的汽车油耗: 请输入要查的汽车马力: static void Main(string[] args) { SqlCo ...