1179: [Apio2009]Atm

Description

Input

第一行包含两个整数N、M。N表示路口的个数,M表示道路条数。接下来M行,每行两个整数,这两个整数都在1到N之间,第i+1行的两个整数表示第i条道路的起点和终点的路口编号。接下来N行,每行一个整数,按顺序表示每个路口处的ATM机中的钱数。接下来一行包含两个整数S、P,S表示市中心的编号,也就是出发的路口。P表示酒吧数目。接下来的一行中有P个整数,表示P个有酒吧的路口的编号

Output

输出一个整数,表示Banditji从市中心开始到某个酒吧结束所能抢劫的最多的现金总数。

Sample Input

6 7
1 2
2 3
3 5
2 4
4 1
2 6
6 5
10
12
8
16
1
5
1 4
4
3
5
6

Sample Output

47

HINT

50%的输入保证N, M<=3000。所有的输入保证N, M<=500000。每个ATM机中可取的钱数为一个非负整数且不超过4000。输入数据保证你可以从市中心沿着Siruseri的单向的道路到达其中的至少一个酒吧。

分析:

这道题其实很迷。首先这道题发现如果在一个强连通分量里面,都可以走到,而且也没有限制走的次数,所以我们可以将在强连通分量里面的点,缩成一个全新的点。之后造出来一个全新的图。boom!新造出来的图可以走一遍最短路spfa。就好了。

至于怎么缩点。
用并查集先找到父亲与儿子。之后每次判断出一个强量通分量就用将他们的父亲全连成第一个数。
之后在新建图(如果一个点的父亲与儿子的父亲不相同,那他们1,连上2,建边)
这个边其实可以重复利用。这样可以节省空间。

#include<cstdio>
#include<string.h>
#include<algorithm>
using namespace std;
struct node{int infont,v,next,val;
}edge[1000010];
int strack[1000010],cnt,father[1000000],heads[500010],d[500010],s,p;
int DFN[1000000],LOW[1000000],bar[1000000],visit[1000010],du[500010];
int n,m,index_1,head;
void address(int x,int y){edge[++cnt].infont=x;edge[cnt].v=y;edge[cnt].next=heads[x];heads[x]=cnt;return ;
}
void tarjan(int x){LOW[x]=DFN[x]=++index_1;visit[x]=1;strack[++head]=x;for(int i=heads[x];i!=-1;i=edge[i].next){if(!DFN[edge[i].v]){tarjan(edge[i].v);LOW[x]=min(LOW[x],LOW[edge[i].v]);}else if(visit[edge[i].v]){LOW[x]=min(LOW[x],DFN[edge[i].v]);}}if(LOW[x]==DFN[x]){while(strack[head]!=x){visit[strack[head]]=0;d[x]+=d[strack[head]];father[strack[head]]=x;head--;}head--;visit[x]=0;}return ;
}
void build(){memset(heads,-1,sizeof(heads));cnt=0;for(int i=1;i<=m;++i){if(father[edge[i].infont]!=father[edge[i].v])address(father[edge[i].infont],father[edge[i].v]);}return ;
}
void SPFA(int x)
{memset(visit,0,sizeof(visit));memset(strack,0,sizeof(strack));memset(du,-0x3f,sizeof(du));int last;last=head=1;strack[head]=x;visit[x]=1;du[x]=d[x];while(head<=last){int news=strack[head];for(int i=heads[news];i!=-1;i=edge[i].next){if(du[edge[i].v]<du[news]+d[edge[i].v]){du[edge[i].v]=du[news]+d[edge[i].v];if(visit[edge[i].v])continue;visit[edge[i].v]=1;strack[++last]=edge[i].v;}}head++;visit[news]=0;}return ;
}
int main( ){memset(heads,-1,sizeof(heads));scanf("%d%d",&n,&m);int a,b;for(int i=1;i<=m;++i){scanf("%d%d",&a,&b);address(a,b);}for(int i=1;i<=n;++i){scanf("%d",&a);d[i]=a;father[i]=i;}for(int i=1;i<=n;++i)if(!DFN[i])tarjan(i);build();scanf("%d%d",&a,&b);SPFA(father[a]);int ans=0;for(int i=1;i<=b;++i){scanf("%d",&a);ans=max(ans,du[father[a]]);}printf("%d",ans);return 0;
}

转载于:https://www.cnblogs.com/uncle-lu/p/5970686.html

BZOJ1179 Atm //缩点+spfa相关推荐

  1. bzoj 1179 抢掠计划atm (缩点+有向无环图DP)

    bzoj 1179 抢掠计划atm (缩点+有向无环图DP) 手动博客搬家: 本文发表于20170716 10:58:18, 原地址https://blog.csdn.net/suncongbo/ar ...

  2. bzoj1179 Atm

    Description Input 第一行包含两个整数N.M.N表示路口的个数,M表示道路条数.接下来M行,每行两个整数,这两个整数都在1到N之间,第i+1行的两个整数表示第i条道路的起点和终点的路口 ...

  3. bzoj 1179: [Apio2009]Atm(Trajan+SPFA)

    1179: [Apio2009]Atm Time Limit: 15 Sec  Memory Limit: 162 MB Submit: 4039  Solved: 1754 [Submit][Sta ...

  4. switch php7.2,在 php 7.3 中 switch 语句中使用 continue

    progressBar走马灯设置 初始值Visible = false; 让progressBar1出现时: progressBar1.Visible = true; progressBar1.Sty ...

  5. P1179: [Apio2009]Atm

    缩点+spfa最短路,因为最终不可能有环,所以直接spfa. 1 const maxe=1000001; 2 type 3 node=record 4 f,t:longint; 5 end; 6 va ...

  6. 【APIO2009-3】抢掠计划

    描述 Siruseri 城中的道路都是单向的.不同的道路由路口连接.按照法律的规定,在每个路口都设立了一个 Siruseri 银行的 ATM 取款机. 令人奇怪的是, Siruseri 的酒吧也都设在 ...

  7. 【luogu P2169 正则表达式】 题解

    题目链接:https://www.luogu.org/problemnew/show/P2169 tarjan缩点 + SPFA 缩完点之后加边注意别写错. 也可以不用建两个图,可以在一张图上判断是否 ...

  8. 【BZOJ1179】atm,tarjan缩点+最长路径

    Time:2016.05.21 Author:xiaoyimi 转载注明出处谢谢 传送门 思路: 题目中是一个带点权的有向图,如果这是一个没有环的图那么问题就很简单,拓扑或者直接求最长(短)路径什么的 ...

  9. bzoj1179[Apio2009]Atm

    bzoj1179[Apio2009]Atm 题意: 给个有向图,每个点有个点权,有些点有酒吧.现在求一个人从任意一点出发获得点权的最大和.要求每个点的点权只能获得一次,且路径最后必须在酒吧结束,可以重 ...

最新文章

  1. 进阶高端,2017年vivo手机用实力说话
  2. 海思3559与全志a83t比较
  3. 谈谈主机和存储连接的多路径技术
  4. 在学术发展上,不论困难与否,应该给自己一个清晰定位
  5. raspberry pi_如何使用Raspberry Pi构建数字针Kong相机
  6. python scrapy框架爬虫_Python Scrapy爬虫框架
  7. 计算机实验报告14,计算机14实验报告模板.doc
  8. CToolBarCtrl工具栏设置总结(转)
  9. 我是一个*** (十三)
  10. 看某帖有感(敬告我,以及我亲爱的朋友们)
  11. bing搜索引擎子域名收集(Python脚本)
  12. 图神经网络和强化学习
  13. 计算机专业英语谐音大全,英语单词谐音记忆法汇总整理
  14. python智能机器人原理_人工智能和Python是什么关系?详细分析!
  15. 0x00007FFEB5D49149 处(位于 Project1.exe 中)有未经处理的异常: Microsoft C++ 异常: cv::Exception,位于内存位置 0x000
  16. 老厉害了!2600亿,紫光集团南京再投半导体生产线
  17. TDSQL携手金蝶云·苍穹,发布“国产数据库联合解决方案”
  18. P4208 [JSOI2008]最小生成树计数
  19. linux 负载均衡技术之 LVS
  20. 历届CSP真题题解-CSP刷真题之路

热门文章

  1. 论文信息系统项目管理的进度管理
  2. cryptico.js java解密_從Cryptico.js中提取RSA私鑰
  3. 新手实用的电脑维护小常识
  4. Linux中shell变量作用域笔记
  5. java 框架mvc_JAVA框架-MVC模式
  6. 怎么安装redhat linux操作系统,红帽RedHat Linux5系统安装指南
  7. JDK 8 新特性 之 default关键字
  8. book电子书数据库设计_如何为杀手book的封面设计写出完美的摘要
  9. Django web开发系列(五)模板
  10. 小到年货大到产业,刘村长的扶贫模式有点厉害!