潘多拉的盒子(bzoj 1194)
Description


Input
第一行是一个正整数S,表示宝盒上咒语机的个数,(1≤S≤50)。文件以下分为S块,每一块描述一个咒语机,按照咒语机0,咒语机1„„咒语机S-1的顺序描述。每一块的格式如下。 一块的第一行有两个正整数n,m。分别表示该咒语机中元件的个数、咒语源输出元的个数(1≤m≤n≤50)。 接下来一行有m个数,表示m个咒语源输出元的标号(都在0到n-1之间)。接下来有n行,每一行两个数。第i行(0≤i≤n-1)的两个数表示pi,0和pi,1(当然,都在0到n-1之间)。
Output
第一行有一个正整数t,表示最长升级序列的长度。
Sample Input
1 1
0
0 0
2 1
0
1 1
0 0
3 1
0
1 1
2 2
0 0
4 1
0
1 1
2 2
3 3
0 0
Sample Output
/*
思路比较简单:对于每对i,j,如果满足i能产生的所有字符串j都能产生,则建边,跑最长路。
但是图可能不是DAG,所以要先预处理缩点,然后再做。
*/
#include<cstdio>
#include<iostream>
#include<cstring>
#define N 60
using namespace std;
int dfn[N],low[N],ins[N],sta[N],val[N],bl[N],indexx,num,top;
int vis[N][N],head[N],head2[N],dp[N],S,cnt,a,b,flag; struct Node{int danger[N],lc[N],rc[N];};Node T[N];
struct node{int to,pre;};node e[N*N*],e2[N*N*]; void add(int u,int v){
e[++cnt].to=v;
e[cnt].pre=head[u];
head[u]=cnt;
}
void add2(int u,int v){
e2[++cnt].to=v;
e2[cnt].pre=head2[u];
head2[u]=cnt;
}
void dfs(int x,int y){
if(vis[x][y]||flag) return;
vis[x][y]=;
if(T[b].danger[y]&&!T[a].danger[x]){flag=;return;}
dfs(T[a].lc[x],T[b].lc[y]);
dfs(T[a].rc[x],T[b].rc[y]);
}
bool check(int i,int j){
flag=;a=i;b=j;
memset(vis,,sizeof(vis));
dfs(,);
if(!flag)return true;
return false;
}
void tarjan(int x){
dfn[x]=low[x]=++indexx;
sta[++top]=x;
ins[x]=;
for(int i=head[x];i;i=e[i].pre){
int v=e[i].to;
if(!dfn[v]){
tarjan(v);
low[x]=min(low[x],dfn[v]);
}
else if(ins[v])
low[x]=min(low[x],low[v]);
}
int u;
if(low[x]==dfn[x]){
++num;
do{
u=sta[top--];
val[num]++;
bl[u]=num;
ins[u]=;
}while(u!=x);
}
}
int dfs2(int x){
if(dp[x])return dp[x];
int maxn=val[x];
for(int i=head2[x];i;i=e2[i].pre)
maxn=max(maxn,dp[e2[i].to]+val[x]);
dp[x]=maxn;
return dp[x];
}
int main(){
scanf("%d",&S);
for(int s=;s<=S;s++){
int n,m;
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++){
int x;scanf("%d",&x);
T[s].danger[x+]=;
}
for(int i=;i<=n;i++){
int x,y;scanf("%d%d",&x,&y);
T[s].lc[i]=x+;T[s].rc[i]=y+;
}
}
for(int i=;i<=S;i++)
for(int j=;j<=S;j++)
if(i!=j&&check(i,j))
add(i,j);
for(int i=;i<=S;i++)if(!dfn[i])tarjan(i);
for(int i=;i<=S;i++)
for(int j=head[i];j;j=e[j].pre)
if(bl[i]!=bl[e[j].to])add2(bl[i],bl[e[j].to]);
int ans=;
for(int i=;i<=num;i++)ans=max(ans,dfs2(i));
printf("%d",ans);
return ;
}
潘多拉的盒子(bzoj 1194)的更多相关文章
- 1194: [HNOI2006]潘多拉的盒子 - BZOJ
Description Input 第一行是一个正整数S,表示宝盒上咒语机的个数,(1≤S≤50).文件以下分为S块,每一块描述一个咒语机,按照咒语机0,咒语机1„„咒语机S-1的顺序描述.每一块的 ...
- 图论(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的最长路.. ------------------------------------- ...
- 1194: [HNOI2006]潘多拉的盒子
1194: [HNOI2006]潘多拉的盒子 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 464 Solved: 221[Submit][Stat ...
- 【BZOJ-1194】潘多拉的盒子 拓扑排序 + DP
1194: [HNOI2006]潘多拉的盒子 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 456 Solved: 215[Submit][Stat ...
- [BZOJ1194][HNOI2006][强连通分量Tarjan+dfs]潘多拉的盒子
[BZOJ1194][HNOI2006]潘多拉的盒子 Input 第一行是一个正整数S,表示宝盒上咒语机的个数,(1≤S≤50).文件以下分为S块,每一块描述一个咒语机,按照咒语机0,咒语机1„„咒语 ...
- BZOJ1194: [HNOI2006]潘多拉的盒子(tarjan)
Description 传说中,有个神奇的潘多拉宝盒.如果谁能打开,便可以拥有幸福.财富.爱情.可是直到真的打开,才发现与之 相随的还有灾难.不幸.其实,在潘多拉制造这个宝盒的时候,设置了一些咒语来封 ...
- BZOJ 1194 [HNOI2006]潘多拉的盒子 (图论+拓扑排序+tarjan)
题面:洛谷传送门 BZOJ传送门 标签里三个算法全都是提高组的,然而..这是一道神题 我们把这道题分为两个部分解决 1.找出所有咒语机两两之间的包含关系 2.求出咒语机的最长上升序列 我们假设咒语机$ ...
- BZOJ 1194: [HNOI2006]潘多拉的盒子 [DP DFA]
传送门 题意: s个DFA,选出尽量多的自动机a0, a1, a2, . . . , at,使得a1包含a0.a2包 含a1,以此类推.s ≤ 50. DFA的字符集为{0,1},有的节点是输出源,节 ...
随机推荐
- C# 移动开发 MasterDetailPage 关闭时报错问题
至上次发表的 MasterDetailPage界面做主App,折腾10天,终于知道问题所在.. 泪奔的是解决这个问题只要一句代码 在MainActivity.cs里 [Activity(Label = ...
- 深入解析Web Services
SOA,面向服务器建构,是一款架构,这几年虽然没前几年那么流行,但是还是有很多企业在用,而Web Services是目前适合做SOA的主要技术之一,通过使用Web Services,应用程序可以对外发 ...
- Elasticsearch插件清单
1.API插件:主要对Elasticsearch添加的API特性或者功能,通常用于搜索或者映射 2. 报警插件: 当Elasticsearch的索引指标超过阀值时就会触发 3. 分词插件:ik是比较好 ...
- Node.js Addons翻译(C/C++扩展)
PS:请先升级Node 6.2.1,Node 升级命令 npm install -g n;n stable.NOde.js扩展是一个通过C/C++编写的动态链接库,并通过Node.js的函数requi ...
- Oracle的Central Inventory和Local inventory详解
很多朋友对Oracle的inventory信息不太了解以至遇到相关的问题不知道如何处理,这篇文章我们将详细讲解Oracle的Central Inventory (oraInventory)和Local ...
- Qt学习笔记12:基本会话框4——总结
文件对话框静态函数 QString QFileDialog::getOpenFileName{ QWidget *parent = 0; //标准文件对话框的父窗口 const QString &am ...
- 完整卸载MySQL数据库
1. 关掉mysql服务 右键“我的电脑”,选择“管理”,打开计算机管理,选择“服务” 右键MySQL服务,选择“停止” 2. 卸载mysql程序 开始菜单->控制面板->程序和功能 3. ...
- freemarker特殊字符输出
期望输出: #{fefefefwewrerwerwrrrre}${fffqqqwwwwwwwwwwwwwwww} 但是以上解析ftl时候会报错!!!!!!!!!!!! 解决办法: 方法1:使用${r& ...
- 雷林鹏分享:Lua 数据类型
Lua是动态类型语言,变量不要类型定义,只需要为变量赋值. 值可以存储在变量中,作为参数传递或结果返回. Lua中有8个基本类型分别为:nil.boolean.number.string.userda ...
- EBS oracle 批量导入更新MOQ(最小拆分量、采购提前期、最小订购量、最小包装量)
EXCEL的列:组织id,供应商编号,供应商地点,料号,最小拆分量.采购提前期.最小订购量.最小包装量 --采购导入更新MOQ四个值,若有为空的那列,会保留原来的值,不会去更新那列的值 PROCEDU ...