ACM/ICPC 之 最短路-SPFA+正逆邻接表(POJ1511(ZOJ2008))
求单源最短路到其余各点,然后返回源点的总最短路长,以构造邻接表的方法不同分为两种解法。
POJ1511(ZOJ2008)-Invitation Cards
改变构造邻接表的方法后,分为两种解法
解法一:
//POJ1511-ZOJ2008
//Time:7766Ms Memory:99112K
//求从1处到各点后再返回1处的最短总路长
//需要构造邻接表和逆邻接表
//构造方法1:vector构造邻接表
//SPFA+邻接表
#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<queue>
using namespace std; #define MAX 1000005
#define INF 0x3f3f3f3f struct Edge {
int u, w;
Edge(int uu, int ww) :u(uu), w(ww) {}
}; vector<Edge> e1[MAX], e2[MAX]; //邻接表-逆邻接表 int n, m;
int d[MAX];
long long sum;
bool v[MAX]; void SPFA(int x, vector<Edge> e[MAX])
{
memset(d, INF, sizeof(d));
memset(v, false, sizeof(v));
queue<int> q;
q.push(x);
d[x] = ;
while (!q.empty()){
int cur = q.front();
q.pop();
v[cur] = false;
for (int i = ; i < e[cur].size(); i++)
{
int u = e[cur][i].u;
if (d[u] > d[cur] + e[cur][i].w)
{
d[u] = d[cur] + e[cur][i].w;
if (!v[u]) { q.push(u); v[u] = true; }
}
}
}
for (int i = ; i <= n; i++)
sum += d[i];
} int main()
{
int T;
scanf("%d", &T);
while (T--) {
sum = ;
memset(e1, , sizeof(e1));
memset(e2, , sizeof(e2));
scanf("%d%d", &n, &m);
while (m--) {
int u, v, w;
scanf("%d%d%d", &u, &v, &w);
e1[u].push_back(Edge(v, w)); //正向
e2[v].push_back(Edge(u, w)); //逆向
} SPFA(, e1);
SPFA(, e2);
printf("%lld\n", sum);
} return ;
}
解法二:
//POJ1511-ZOJ2008
//Time:2000Ms Memory:36424K
//求从1处到各点后再返回1处的最短总路长
//需要构造邻接表和逆邻接表
//构造方法2:偏序关系构造邻接表
//SPFA+邻接表
#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<queue>
using namespace std; #define MAX 1000005
#define INF 0x3f3f3f3f struct Edge {
int u, w, next;
Edge() {}
Edge(int uu, int ww, int nn) :u(uu), w(ww), next(nn) {}
}e1[MAX], e2[MAX]; //邻接表-逆邻接表 int h1[MAX], h2[MAX]; //正表表头-逆表表头
int n, m;
int d[MAX];
long long sum;
bool v[MAX]; void SPFA(int x, Edge e[MAX], int h[MAX])
{
memset(d, INF, sizeof(d));
memset(v, false, sizeof(v));
queue<int> q;
q.push(x);
d[x] = ;
while (!q.empty()){
int cur = q.front();
q.pop();
v[cur] = false;
for (int i = h[cur]; i != -; i = e[i].next)
{
int u = e[i].u;
int w = e[i].w;
if (d[u] > d[cur] + w)
{
d[u] = d[cur] + w;
if (!v[u]) { q.push(u); v[u] = true; }
}
}
}
for (int i = ; i <= n; i++)
sum += d[i];
} int main()
{
int T;
scanf("%d", &T);
while (T--) {
sum = ;
memset(e1, , sizeof(e1));
memset(e2, , sizeof(e2));
memset(h1, -, sizeof(h1));
memset(h2, -, sizeof(h2));
scanf("%d%d", &n, &m);
for (int i = ; i < m; i++) {
int u, v, w;
scanf("%d%d%d", &u, &v, &w);
e1[i] = Edge(v, w, h1[u]);
e2[i] = Edge(u, w, h2[v]);
h1[u] = h2[v] = i;
} SPFA(, e1, h1);
SPFA(, e2, h2);
printf("%lld\n", sum);
} return ;
}
ACM/ICPC 之 最短路-SPFA+正逆邻接表(POJ1511(ZOJ2008))的更多相关文章
- SPFA中 正逆邻接表的建立
正邻接表的建立: 先定义一个结构体: struct node { int r,v,w,next; }Map[]; 每输入一组数据 就通过Add函数加入到邻接表中,上图已经说得很明白了,结合着下面的代码 ...
- HDU 1874 畅通工程续(最短路/spfa Dijkstra 邻接矩阵+邻接表)
题目链接: 传送门 畅通工程续 Time Limit: 1000MS Memory Limit: 65536K Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路. ...
- ACM/ICPC 之 最短路-Floyd+SPFA(BFS)+DP(ZOJ1232)
这是一道非常好的题目,融合了很多知识点. ZOJ1232-Adventrue of Super Mario 这一题折磨我挺长时间的,不过最后做出来非常开心啊,哇咔咔咔 题意就不累述了,注释有写,难点在 ...
- 2016 ACM/ICPC Asia Regional Qingdao Online 1001/HDU5878 打表二分
I Count Two Three Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- 最短路径SPFA算法(邻接表存法)
queue <int> Q; void SPFA (int s) { int i, v; for(int i=0; i<=n; i++) dist[i]=INF; //初始化每点i到 ...
- POJ 3013 SPFA算法,邻接表的使用
Big Christmas Tree Time Limit: 3000MS Memory Limit: 131072K Total Submissions: 19029 Accepted: 4 ...
- POJ 3259 Wormholes(最短路&spfa正权回路)题解
题意:给你m条路花费时间(双向正权路径),w个虫洞返回时间(单向负权路径),问你他能不能走一圈回到原点之后,时间倒流. 思路:题意有点难看懂,我们建完边之后找一下是否存在负权回路,存在则能,反之不能. ...
- POJ 1860 Currency Exchange(最短路&spfa正权回路)题解
题意:n种钱,m种汇率转换,若ab汇率p,手续费q,则b=(a-q)*p,你有第s种钱v数量,问你能不能通过转化让你的s种钱变多? 思路:因为过程中可能有负权值,用spfa.求是否有正权回路,dis[ ...
- ACM/ICPC 之 数论-素数筛选法 与 "打表"思路(POJ 1595)
何为"打表"呢,说得简单点就是: 有时候与其重复运行同样的算法得出答案,还不如直接用算法把这组数据所有可能的答案都枚举出来存到一个足够大的容器中去-例如数组(打表),然后再输入数据 ...
随机推荐
- plsql常用函数汇总
在SQLPLUS下,实现中-英字符集转换alter session set nls_language='AMERICAN';alter session set nls_language='SIMPLI ...
- [CentOs7]iptables防火墙安装与设置
摘要 CentOS 7.0默认使用的是firewall作为防火墙,如果改为iptables防火墙,如何操作? 关闭firewall: systemctl stop firewalld.service ...
- 如何在html中做圆角矩形和 只有右边的"分隔线"
这个网站满好的,可以常看看 css-matic中有几个很好的写css可视化的工具 其实做css 版式布局等都可以有工具的 推荐40个优秀的免费CSS工具 debugger正则表达式在线 其实是对(理论 ...
- typecho除了首页其他大部分网页404怎么办?
server { listen ; server_name blog.localhost; #绑定域名 index index.htm index.html index.php; #默认文件 root ...
- TeX — Beauty and Fun
我是初学者,你推荐使用什么发行的 TeX? 我应该用 LaTeX 吗? 我认为最好的发行是 TeXLive CD,它不但包含了所有操作系统需要的程序,而且有许许多多宏包,如果你不是特别特殊的用户,有了 ...
- js(jquery)代码在页面上实时地显示时间
一.引入jquery 二.HTML代码 三.js代码 1)引入js代码 2)下面是完整的js代码
- CentOS6.3编译安装Memcached集群分布式缓存代理Magent-0.6出错汇总
参考文章:Memcached集群/分布式/高可用 及 Magent缓存代理搭建过程 详解,搭建Magent,在编译的过程中会出现很多错误: #编译安装安装magent到 /usr/local/mage ...
- 关于css3的动画总结
旋转:transform:rotate(xxdeg)扭曲:transform:skey(x,y)缩放:transform:scale(x,y)变形位移:transform:translate(x,y) ...
- Mac OS X 11以上系统的Rootless机制问题
由于项目紧,系统一直停留在10版本,最近清闲之后,第一件事就是升级了系统,到11El Capitan版本. 本来想着随便升级了,可能有好玩的东东,结果好玩的木有看见,项目开发环境崩溃了,何其衰耶? 废 ...
- Oracle 数据库1046事件
例子: session 2: SQL> connect test/test Connected. select * from v$mystat where rownum=1; 143 selec ...