bzoj 1179 [Apio2009]Atm 缩点+最短路
[Apio2009]Atm
Time Limit: 15 Sec Memory Limit: 162 MB
Submit: 4290 Solved: 1893
[Submit][Status][Discuss]
Description

Input
Output
输出一个整数,表示Banditji从市中心开始到某个酒吧结束所能抢劫的最多的现金总数。
Sample Input
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
HINT
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<queue> #define N 500007
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-;ch=getchar();}
while(isdigit(ch)){x=(x<<)+(x<<)+ch-'';ch=getchar();}
return x*f;
} int n,m,S,p;
int dis[N],w[N],val[N];
int cnt,hed[N],rea[N<<],nxt[N<<];
int cnt1,hed1[N],rea1[N<<],nxt1[N<<];
int tim,tot,scc,bel[N],stk[N],dfn[N],low[N];
bool flag[N],instk[N],flag1[N]; void add(int u,int v)
{
nxt[++cnt]=hed[u];
hed[u]=cnt;
rea[cnt]=v;
}
void add1(int u,int v)
{
nxt1[++cnt1]=hed1[u];
hed1[u]=cnt1;
rea1[cnt1]=v;
}
void Tarjan(int u)
{
dfn[u]=low[u]=++tim;
stk[++tot]=u,instk[u]=true;
for (int i=hed[u];i!=-;i=nxt[i])
{
int v=rea[i];
if (!dfn[v])
{
Tarjan(v);
low[u]=min(low[u],low[v]);
}
else if (instk[v]) low[u]=min(low[u],dfn[v]);
}
if (low[u]==dfn[u])
{
int x=-;scc++;
while (x!=u)
{
x=stk[tot--];
bel[x]=scc;
instk[x]=false;
}
}
}
void Spfa(int st)
{
queue<int>q;q.push(bel[st]);bool boo[N];
memset(boo,,sizeof(boo));boo[bel[st]]=true;
for (int i=;i<=scc;i++) dis[i]=;
dis[bel[st]]=val[bel[st]];
while (!q.empty())
{
int u=q.front();q.pop();
for (int i=hed1[u];i!=-;i=nxt1[i])
{
int v=rea1[i];
if (dis[u]+val[v]>dis[v])
{
dis[v]=dis[u]+val[v];
if (!boo[v]) q.push(v),boo[v]=true;
}
}
boo[u]=false;
}
}
int main()
{
freopen("fzy.in","r",stdin);
freopen("fzy.out","w",stdout); memset(hed,-,sizeof(hed));
memset(hed1,-,sizeof(hed1));
n=read(),m=read();
for (int i=;i<=m;i++)
{
int x=read(),y=read();
add(x,y);
}
for (int i=;i<=n;i++) w[i]=read();
S=read(),p=read();
for (int i=;i<=p;i++)
flag[read()]=true;
for (int i=;i<=n;i++)
if (!dfn[i]) Tarjan(i);
for (int u=;u<=n;u++)
{
for (int i=hed[u];i!=-;i=nxt[i])
{
int v=rea[i];
if (bel[u]!=bel[v]) add1(bel[u],bel[v]);
}
flag1[bel[u]]|=flag[u];
val[bel[u]]+=w[u];
}
Spfa(S);
int ans=;
for (int i=;i<=scc;i++)
ans=max(ans,dis[i]*flag1[i]);
printf("%d\n",ans);
}
bzoj 1179 [Apio2009]Atm 缩点+最短路的更多相关文章
- BZOJ 1179: [Apio2009]Atm( tarjan + 最短路 )
对于一个强连通分量, 一定是整个走或者不走, 所以tarjan缩点然后跑dijkstra. ------------------------------------------------------ ...
- bzoj 1179 [Apio2009]Atm——SCC缩点+spfa
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1179 显然SCC缩点. 然后准备倒着拓扑序推到st,结果WA. 听TJ说dj求最长路会发生不 ...
- bzoj 1179: [Apio2009]Atm
Description Input 第 一行包含两个整数N.M.N表示路口的个数,M表示道路条数.接下来M行,每行两个整数,这两个整数都在1到N之间,第i+1行的两个整数表示第i条道路 的起点和终点的 ...
- bzoj 1179[Apio2009]Atm (tarjan+spfa)
题目 输入 第一行包含两个整数N.M.N表示路口的个数,M表示道路条数.接下来M行,每行两个整数,这两个整数都在1到N之间,第i+1行的两个整数表示第i条道路的起点和终点的路口编号.接下来N行,每行一 ...
- BZOJ 1179 [Apio2009]Atm(强连通分量)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1179 [题目大意] 给出一张有向带环点权图,给出一些终点,在路径中同一个点的点权只能累 ...
- bzoj 1179: [Apio2009]Atm【tarjan+spfa】
明明优化了spfa还是好慢-- 因为只能取一次值,所以先tarjan缩点,把一个scc的点权和加起来作为新点的点权,然后建立新图.在新图上跑spfa最长路,最后把酒吧点的dis取个max就是答案. # ...
- 缩点+spfa最长路【bzoj】 1179: [Apio2009]Atm
[bzoj] 1179: [Apio2009]Atm Description Siruseri 城中的道路都是单向的.不同的道路由路口连接.按照法律的规定, 在每个路口都设立了一个 Siruseri ...
- 1179: [Apio2009]Atm
1179: [Apio2009]Atm Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 1629 Solved: 615[Submit][Status ...
- BZOJ1179 : [Apio2009]Atm 缩点+spfa
1179: [Apio2009]Atm Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 2069 Solved: 826[Submit][Status ...
随机推荐
- PAT-甲级解题目录
PAT甲级题目:点这里 pat解题列表 题号 标题 题目类型 10001 1001 A+B Format (20 分) 字符串处理 1003 1003 Emergency (25 分) 最短路径 ...
- RL_Learning
Key Concepts in RL 标签(空格分隔): RL_learning OpenAI Spinning Up原址 states and observations (状态和观测) action ...
- Machine Learning笔记整理 ------ (四)线性模型
1. 线性模型 基本形式:给定由d个属性描述的样本 x = (x1; x2; ......; xd),其中,xi是x在第i个属性上的取值,则有: f(x) = w1x1 + w2x2 + ...... ...
- C++ 学习笔记之——字符串和字符串流
1. 字符数组 字符数组,也就是存放字符类型数据的数组,只不过字符数组的结尾必须是 '\0'.C++ 已经提供了一些字符串处理函数,这些函数被封装在头文件 和 <string.h> 中. ...
- dice2win
触发交易 转0个 https://etherscan.io/tx/0x784e80167353a886183106cbe3bd15e614cafdb5d6885ccd101177aa0f937a36 ...
- avalonJS入门
前端神器avalonJS入门(一) posted @ 2014-10-31 17:44 vajoy 阅读(8759) 评论(42) 编辑 收藏 avalonJS是司徒正美开发和维护的前端mvvm框 ...
- [leetcode-693-Binary Number with Alternating Bits]
Given a positive integer, check whether it has alternating bits: namely, if two adjacent bits will a ...
- HDU 1250 Hat's Fibonacci(高精度)
Problem Description A Fibonacci sequence is calculated by adding the previous two members the sequen ...
- 将footer固定在页面最下方
方法一: HTML结构: <div id="id_wrapper"> <div id="id_header"> Header Block ...
- iconFont 阿里巴巴矢量图标使用方法
挑选图标的过程(共6步) 进入网站:Iconfont网址:http://www.iconfont.cn 点击网站上方的“官方图标库”,选择自己喜欢的图标.在这里我选择天猫的图标库. 选择好自己喜欢的图 ...