CF1137C 题解
考虑把每个点进行拆成 \(d\) 个点表示星期几走到这个点,那么原图上的边 \((u,v)\) 就被拆成\((pos_{u,i},pos_{v,i+1})\) 表示星期的变化。
然后考虑进行缩点,在一个强连通分量内的同一个博物馆只能被计算一次?
那要是一个博物馆出现在两个强连通分量内呢?
可以证明这种情况不会出现,因为边 \((pos_{u,i},pos_{v,j})\) 和边 \((pos_{v,j},pos_{u,k})\) 代表原图中存在边 \((u,v)\) 与 \((v,u)\) 且类似的可以证明一个博物馆拆成的点一定在一个强连通分量中,那么接下来计算强连通分量内的贡献,拓扑排序后跑一遍最长路即可。
// LUOGU_RID: 122368344
#include<bits/stdc++.h>
#define pos(i,j)((i-1)*d+j-1)
using namespace std;
int n,d,m;
const int maxn = 1e5*51+1;
struct Node{
int v,to;
}e1[maxn<<1],e2[maxn<<1];
int tot1,tot2;
int head[maxn][2];
void add1(int u,int v){
e1[++tot1].v=v;
e1[tot1].to=head[u][0];
head[u][0]=tot1;
}
void add2(int u,int v){
e2[++tot2].v=v;
e2[tot2].to=head[u][1];
head[u][1]=tot2;
}
int dfncnt,vis[maxn],dfn[maxn],low[maxn],color,col[maxn];
bitset<maxn> point;
stack<int> st;
void tanjan(int u){
st.push(u);
vis[u]=1;
low[u]=dfn[u]=++dfncnt;
for(int i=head[u][0];i;i=e1[i].to){
int v=e1[i].v;
if(dfn[v]==0){
tanjan(v);
low[u]=min(low[u],low[v]);
}
else if(vis[v]==1){
low[u]=min(low[u],dfn[v]);
}
}
if(dfn[u]==low[u]){
++color;
while(st.top()!=u){
col[st.top()]=color;
vis[st.top()]=0;
st.pop();
}
col[u]=color;
vis[u]=0;
st.pop();
}
}
void bfs(){//处理从 1 号节点出发可以抵达的点
for(int i=1;i<=color;i++) low[i]=0;
queue<int> q;
q.push(col[pos(1,1)]);
while(q.size()>0){
int u=q.front();
q.pop();
for(int i=head[u][1];i;i=e2[i].to){
int v=e2[i].v;
low[v]++;
if(low[v]==1) q.push(v);
}
}
}
unordered_map<int,int> use[100001];
void build(){//处理缩点后的连边
for(int u=pos(1,1);u<=pos(n,d);u++){
for(int i=head[u][0];i;i=e1[i].to){
int v=e1[i].v;
int U=col[u],V=col[v];
if(U==V) continue;
add2(U,V);
}
}
for(int i=1;i<=color;i++) vis[i]=0;
for(int u=pos(1,1);u<=pos(n,d);u++){
if(point[u]==1&&use[u/d][col[u]]==0){
vis[col[u]]++;
use[u/d][col[u]]=1;
}
}
}
int answer;
void topo(){
queue<int> q;
for(int i=1;i<=color;i++) dfn[i]=-1000000;
dfn[col[pos(1,1)]]=vis[col[pos(1,1)]];
q.push(col[pos(1,1)]);
while(q.size()>0){
int u=q.front();
q.pop();
for(int i=head[u][1];i;i=e2[i].to){
int v=e2[i].v;
dfn[v]=max(dfn[v],dfn[u]+vis[v]);
low[v]--;
if(low[v]==0) q.push(v);
}
}
for(int i=1;i<=color;i++) answer=max(answer,dfn[i]);
}
int main(){
cin>>n>>m>>d;
for(int i=1;i<=m;i++){
int u,v;
cin>>u>>v;
for(int j=1;j<=d;j++) add1(pos(u,j),pos(v,j%d+1));
}
for(int i=1;i<=n;i++){
for(int j=1;j<=d;j++){
char c;
cin>>c;
point[pos(i,j)]=c-'0';
}
}
for(int i=pos(1,1);i<=pos(n,d);i++) if(dfn[i]==0) tanjan(i);
build();
bfs();
topo();
cout<<answer<<'\n';
}
CF1137C 题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- ansible(17)--ansible的archive和unarchive模块
1. archive模块 功能:在远端主机打包与压缩: 主要参数如下: 参数 说明 path 要压缩的文件或目录 dest 压缩后的文件 format 指定打包压缩的类型:bz2.gz.tar.xz. ...
- C语言:send + more = money,单词相加求解字母数字谜问题
我用的是穷举法,虽然有点笨,但是在想不到其他更好的方法对我而言就是穷举法. 有程序员大大想到其他方法也可以私信我一起探讨一下~ #include<stdio.h> int main() { ...
- 在唯一密钥属性“name”设置为“XXX”时,无法添加类型为“add”的重复集合项
我是在调试时,更改了项目url出现的问题,没有改端口号,只是改了"/"后面的地址 这个是我是改哈端口号就好了,改了端口号就重新建立虚拟目录了. 感觉是因为端口号没变,但项目url变 ...
- Intel HDSLB 高性能四层负载均衡器 — 基本原理和部署配置
前言 在上一篇<Intel HDSLB 高性能四层负载均衡器 - 快速入门和应用场景>中,我们着重介绍了 HDSLB(High Density Scalable Load Balancer ...
- 莫烦tensorflow学习记录 (1)session会话控制、variable变量、placeholder传入值
https://mofanpy.com/tutorials/machine-learning/tensorflow/session/ Session 会话控制 #https://mofanpy.com ...
- ReplayKit2 采集音视频回调格式
一.音频 ReplayKit2 RPSampleBufferTypeAudioApp sampleBuffer = CMSampleBuffer 0x100500c50 retainCount: 1 ...
- 我用docker搭建的第一个博客
其实很早就听说了docker这个东西,一直以来想玩不知道拿什么下手,再加上前段时间听了一个思科的年度网络报告讲解里面稍微提了一下docker的优势以及网络即服务的概念.想通了,不是每一步都得亲历亲为, ...
- 8.19考试总结(NOIP模拟44)[Emotional Flutter·Medium Counting·Huge Counting·字符消除2 ]
在自称善意的之时,即存恶意. 前言 几乎是大暑假的最后一次考试了. 我也迎来了我的第一次报零(雾 T1 Emotional Flutter 解题思路 比较考验思维能力,其实就是区间覆盖问题. 我考场上 ...
- 详解 JS 中的事件循环、宏/微任务、Primise对象、定时器函数,以及其在工作中的应用和注意事项
为什么会突然想到写这么一个大杂烩的博文呢,必须要从笔者几年前的一次面试说起 当时的我年轻气盛,在简历上放了自己的博客地址,而面试官应该是翻了我的博客,好几道面试题都是围绕着我的博文来提问 其中一个问题 ...
- kettle从入门到精通 第五十三课 ETL之kettle MQTT/RabbitMQ consumer实战
1.上一节课我们学习了MQTT producer 生产者步骤,MQTT consumer消费者步骤.该步骤可以从支持MRQTT协议的中间件获取数据,该步骤和kafka consumer 一样可以处理实 ...