【强连通分量】Bzoj1194 HNOI2006 潘多拉的盒子
Description


Sulotion
首先要对每对咒语机建图,判断机器a是否能生成所有机器b生成的
如果跑一个相同的串,最后结束的点b可输出a不可输出,判断就为否
大概就用这种思路,f[x][y]表示a中跑到x b中跑到y是否可行,然后大概记忆化搜索,只有两种转移
//感觉跑自动机的题目经常要这么(跑到了哪一个结点)表示状态
建图之后可能会有环(a和b生成的一样),于是强连通分量缩点
变成了DAG,然后dp记忆化搜索出答案
Code
一开始边的数组也直接用maxn了,最近怎么总是犯低级错误
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn=,maxm=1e4+; int S;
struct box{
int n,m,p[maxn][],ok[maxn];
}a[maxn];
int head[maxn],e[maxm],nxt[maxm],tot;
int adde(int u,int v){
e[++tot]=v,nxt[tot]=head[u];
head[u]=tot;
}
int low[maxn],pre[maxn],clock;
int scc[maxn],size[maxn],cnt,r[maxn],t; int c,d;
int vis[maxn][maxn];
int pd(int x,int y){
if(vis[x][y]) return ;
if(!a[c].ok[x]&&a[d].ok[y]) return ;
vis[x][y]=;
if(!pd(a[c].p[x][],a[d].p[y][])) return ;
if(!pd(a[c].p[x][],a[d].p[y][])) return ;
return ;
} int tarjan(int u){
pre[u]=low[u]=++clock;
r[++t]=u;
for(int i=head[u];i;i=nxt[i]){
int v=e[i];
if(!pre[v]){
tarjan(v);
low[u]=min(low[u],low[v]);
}
else if(!scc[v]){
low[u]=min(low[u],pre[v]);
}
}
if(pre[u]==low[u]){
++cnt;
while(t){
scc[r[t]]=cnt;
size[cnt]++;
if(r[t--]==u) break;
}
}
} int f[maxn],G[maxn][maxn];
int dfs(int u){
if(f[u]) return f[u];
int ret=;
for(int v=;v<=cnt;v++)
if(G[u][v]) ret=max(ret,dfs(v));
return f[u]=ret+size[u];
} int main(){
int x;
scanf("%d",&S);
for(int k=;k<=S;k++){
scanf("%d%d",&a[k].n,&a[k].m);
for(int i=;i<=a[k].m;i++)
scanf("%d",&x),a[k].ok[x+]=;
for(int i=;i<=a[k].n;i++){
scanf("%d%d",&a[k].p[i][],&a[k].p[i][]);
a[k].p[i][]++,a[k].p[i][]++;
}
} for(int i=;i<=S;i++)
for(int j=;j<=S;j++)
if(i!=j){
memset(vis,,sizeof(vis));
c=i,d=j;
if(pd(,)) adde(c,d);
} for(int i=;i<=S;i++)
if(!pre[i]) tarjan(i); for(int i=;i<=S;i++)
for(int j=head[i];j;j=nxt[j])
if(scc[i]!=scc[e[j]]) G[scc[i]][scc[e[j]]]=; int ans=;
for(int i=;i<=cnt;i++)
ans=max(ans,dfs(i)); printf("%d\n",ans);
return ;
}
【强连通分量】Bzoj1194 HNOI2006 潘多拉的盒子的更多相关文章
- [BZOJ1194][HNOI2006][强连通分量Tarjan+dfs]潘多拉的盒子
[BZOJ1194][HNOI2006]潘多拉的盒子 Input 第一行是一个正整数S,表示宝盒上咒语机的个数,(1≤S≤50).文件以下分为S块,每一块描述一个咒语机,按照咒语机0,咒语机1„„咒语 ...
- BZOJ1194: [HNOI2006]潘多拉的盒子(tarjan)
Description 传说中,有个神奇的潘多拉宝盒.如果谁能打开,便可以拥有幸福.财富.爱情.可是直到真的打开,才发现与之 相随的还有灾难.不幸.其实,在潘多拉制造这个宝盒的时候,设置了一些咒语来封 ...
- 图论(Tarjan缩点):BZOJ 1194: [HNOI2006]潘多拉的盒子
1194: [HNOI2006]潘多拉的盒子 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 344 Solved: 181[Submit][Stat ...
- BZOJ 1194: [HNOI2006]潘多拉的盒子( BFS + tarjan + dp )
O(S²)枚举2个诅咒机, 然后O(n²)BFS去判断. 构成一个有向图, tarjan缩点, 然后就是求DAG的最长路.. ------------------------------------- ...
- 【BZOJ-1194】潘多拉的盒子 拓扑排序 + DP
1194: [HNOI2006]潘多拉的盒子 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 456 Solved: 215[Submit][Stat ...
- 1194: [HNOI2006]潘多拉的盒子
1194: [HNOI2006]潘多拉的盒子 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 464 Solved: 221[Submit][Stat ...
- 1194: [HNOI2006]潘多拉的盒子 - BZOJ
Description Input 第一行是一个正整数S,表示宝盒上咒语机的个数,(1≤S≤50).文件以下分为S块,每一块描述一个咒语机,按照咒语机0,咒语机1„„咒语机S-1的顺序描述.每一块的 ...
- 【bzoj1194】 HNOI2006—潘多拉的盒子
http://www.lydsy.com/JudgeOnline/problem.php?id=1194 (题目链接) 题意 给出S个自动机,如果一个自动机u的所有状态是另一个自动机v的状态的子集,那 ...
- BZOJ 1194: [HNOI2006]潘多拉的盒子 [DP DFA]
传送门 题意: s个DFA,选出尽量多的自动机a0, a1, a2, . . . , at,使得a1包含a0.a2包 含a1,以此类推.s ≤ 50. DFA的字符集为{0,1},有的节点是输出源,节 ...
随机推荐
- Day8 封装 静态属性property
封装:将类的属性隐藏 #先看如何隐藏 1,在定义的属性之前加入__. class Foo: __N=111111 #_Foo__N def __init__(self,name): self.__Na ...
- 【读书笔记】C++Primer---第二章
1.C++基本数据类型:字符型.整型.浮点型等: 2.算术类型如下表,下表只是表示C++要求的最小储存空间,但是一般编译器使用的都比所要求的储存空间大,以前类型所能表示的最大值也因机器的不同而有不同的 ...
- python---用户登录程序
需求: 1. 用户登录,判断用户名密码是否正确 2. 密码输入三次不对则锁定账号 3. 锁定账号无法登录 分析: 1. 输入账号,判断账号是否存在,即账号是否在账号文件中存在: 2. 如果账号存在,则 ...
- 微信小程序之获取用户位置权限(拒绝后提醒)
微信小程序获取用户当前位置有三个方式: 1. wx.getLocation(多与wx.openLocation一起用) 获取当前的精度.纬度.速度.不需要授权.当type设置为gcj02 返回可用于w ...
- cocos2d-x_ Windows下Android环境搭建
在Windows环境下编译cocos2d-x-3.0 Android-NDK编译:cocos2d-x(二) Mac 下搭建:http://www.cocoachina.com/bbs/read.php ...
- Hibernate Session总结
现在我们可以在 IDEA 下新建一个 Hibernate 项目,接着上次内容这次主要总结一下 Hibernate 的 Session,及其核心方法. Session 概述 Session 接口是 Hi ...
- python_重写数组
class MyArray: '''All the elements in this array must be numbers''' def __IsNumber(self,n): if not i ...
- 高通调试 SPI 屏的 bug
1. spi调试问题: 问题描述: spi屏幕lk启动的时候正常出现小企鹅,到kernel启动的过程黑屏并且花屏才到开机动画: 2. 黑屏的三个阶段: 参照:黑屏分析 分析开机过程黑屏,首先需要定位黑 ...
- restTemplate设置访问超时
(一)RestTemplate 客户端 1.RestTemplate 是Spring的封装,需要spring的包 spring-web-3.0.7.RELEASE.jar 2.客户端代码: /** * ...
- java并发之CyclicBarrier
一.CyclicBarrier简述 一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point).在涉及一组固定大小的线程的程序中,这些线程必须不时地互 ...