[CTSC2008]祭祀(构造方案)
前面的话
这道题显然就是最长反链
根据 \(Dilworth\) 定理:最小链覆盖数 = 最长反链长度
然后传递闭包跑匹配即可
\(luogu\)交了一下,\(WA\) 了
\(QAQ\)
本来各种 \(OJ\) 上都是只要求最长反链,不需要构造方案
虽然原题要构造
然后 \(luogu\) 上的同志写了个 \(SPJ\), 然后 \(luogu\) 就要输出方案了
切不掉很难受
Sol
先放两个博客:
首先建图后发现最大独立集和最小点覆盖互为补集
而这个图中的最大独立集就是最长反链可能,猜的...(因为两两不可到达)
然后只要知道怎么构造最小点覆盖就好了
第一步
对于一个二分图,这样来做:
先最大匹配
每次从左边找到一个未匹配点增广(假的增广,显然增广不了,因为已经是最大匹配)
然后标记点
最后左边没有标记过的点和右边标记过的点就是最小点覆盖
伪证:因为一条假的增广路一定是左边的点作为开头和结尾的,所以选右边的就能覆盖这个假的增广路
去掉这些点就是要找的最长反链
第二步
找到所有可以出现在最长反链上的点
枚举每个点,删掉它以及可以到达它和它可以到达的点(邻居)
再求最长反链,如果大小减小了 \(1\),这个点就是可以的(显然选这个点不会和当前的集合冲突)
代码
# include <bits/stdc++.h>
# define IL inline
# define RG register
# define Fill(a, b) memset(a, b, sizeof(a))
using namespace std;
typedef long long ll;
IL int Input(){
RG char c = getchar(); RG int x = 0, z = 1;
for(; c < '0' || c > '9'; c = getchar()) z = c == '-' ? -1 : 1;
for(; c >= '0' && c <= '9'; c = getchar()) x = (x << 1) + (x << 3) + (c ^ 48);
return x * z;
}
const int maxn(205);
const int maxm(1005);
int n, m, ans, match[maxn], to[maxn], vis[maxn], idx, f[maxn][maxn], g[maxn][maxn];
int ban[maxn], s[maxn], t[maxn];
IL int Dfs(RG int u){
if(ban[u]) return 0;
for(RG int i = 1; i <= n; ++i)
if(f[u][i] && vis[i] != idx && !ban[i]){
vis[i] = idx;
if(!match[i] || Dfs(match[i])){
to[u] = i, match[i] = u;
return 1;
}
}
return 0;
}
IL void Calc(RG int u){
if(s[u]) return;
s[u] = 1;
for(RG int i = 1; i <= n; ++i)
if(f[u][i] && !t[i]) t[i] = 1, Calc(match[i]);
}
int main(RG int argc, RG char* argv[]){
n = Input(), m = Input();
for(RG int i = 1; i <= m; ++i) g[Input()][Input()] = 1;
for(RG int i = 1; i <= n; ++i)
for(RG int j = 1; j <= n; ++j)
for(RG int k = 1; k <= n; ++k) g[j][k] |= g[j][i] & g[i][k];
memcpy(f, g, sizeof(f)), ans = n;
for(RG int i = 1; i <= n; ++i) ++idx, ans -= Dfs(i);
printf("%d\n", ans);
for(RG int i = 1; i <= n; ++i) if(!to[i]) Calc(i);
for(RG int i = 1; i <= n; ++i) printf("%d", s[i] && !t[i]);
puts("");
for(RG int nw = 1; nw <= n; ++nw){
for(RG int i = 1; i <= n; ++i) match[i] = to[i] = 0;
RG int ret = 0, nn = 0;
Fill(f, 0), Fill(ban, 0);
for(RG int i = 1; i <= n; ++i)
if(g[i][nw] || g[nw][i] || i == nw) ban[i] = 1;
else ++nn;
ret = nn;
for(RG int i = 1; i <= n; ++i)
for(RG int j = 1; j <= n; ++j)
if(!ban[i] && !ban[j]) f[i][j] = g[i][j];
for(RG int i = 1; i <= n; ++i) if(!ban[i]) ++idx, ret -= Dfs(i);
printf("%d", ret == ans - 1);
}
return 0;
}
[CTSC2008]祭祀(构造方案)的更多相关文章
- BZOJ 1143 1143: [CTSC2008]祭祀river 最长反链
1143: [CTSC2008]祭祀river Description 在遥远的东方,有一个神秘的民族,自称Y族.他们世代居住在水面上,奉龙王为神.每逢重大庆典, Y族都会在水面上举办盛大的祭祀活动. ...
- Bzoj 2718: [Violet 4]毕业旅行 && Bzoj 1143: [CTSC2008]祭祀river 传递闭包,二分图匹配,匈牙利,bitset
1143: [CTSC2008]祭祀river Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1878 Solved: 937[Submit][St ...
- bzoj 1143: [CTSC2008]祭祀river / 2718: [Violet 4]毕业旅行 -- 二分图匹配
1143: [CTSC2008]祭祀river Time Limit: 10 Sec Memory Limit: 162 MB Description 在遥远的东方,有一个神秘的民族,自称Y族.他们 ...
- BZOJ1143 [CTSC2008]祭祀river 【二分图匹配】
1143: [CTSC2008]祭祀river Time Limit: 10 Sec Memory Limit: 162 MB Submit: 3236 Solved: 1651 [Submit] ...
- bzoj1143(2718)[CTSC2008]祭祀river(最长反链)
1143: [CTSC2008]祭祀river Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2781 Solved: 1420[Submit][S ...
- BZOJ 1143: [CTSC2008]祭祀river 最长反链
1143: [CTSC2008]祭祀river Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline ...
- 1143: [CTSC2008]祭祀river(最长反链)
1143: [CTSC2008]祭祀river 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1143 Description: 在遥远的 ...
- P4298 [CTSC2008]祭祀
P4298 [CTSC2008]祭祀 传递闭包跑一遍按联通建图 $(1)$最长反链长度=最小链覆盖=n-最大匹配 $(2)$定义作为最大匹配出现在左端点的集合为$S$,作为最大匹配出现在右端点的集合为 ...
- 洛谷 P4298: bzoj 1143: [CTSC2008]祭祀
题目传送门:洛谷 P4298. 题意简述: 给定一个 \(n\) 个点,\(m\) 条边的简单有向无环图(DAG),求出它的最长反链,并构造方案. 最长反链:一张有向无环图的最长反链为一个集合 \(S ...
随机推荐
- JSP入门之自定义标签
第二部分简单讲解:主要讲解el表达式,核心标签库.本章主要讲解:自定义标签库:404页面,505页面,错误页面配置方法 全部代码下载:链接 1.JSP自定义标签: 自定义标签是用户定义的JSP语言元素 ...
- XorPay 个人支付平台增加 个人支付宝支付接口
XorPay 今天新增 个人支付宝当面付 接口,欢迎大家使用. 「 XorPay 支付平台」 已经同时支持 个人微信支付接口 和 个人支付宝接口. 个人可用的 支付宝/微信支付 接口,支持 当面付 ...
- [JZOJ6075]【GDOI2019模拟2019.3.20】桥【DP】【线段树】
Description N,M<=100000,S,T<=1e9 Solution 首先可以感受一下,我们把街道看成一行,那么只有给出的2n个点的纵坐标是有用的,于是我们可以将坐标离散化至 ...
- 思科网络设备配置AAA认证
思科网络设备配置AAA认证登陆,登陆认证后直接进入#特权模式,下面以Cisco 3750G-24TS-S为例,其他设备配置完全是一样的,进入config terminal后命令如下: 前面是加2个不同 ...
- win8.1中向IIS注册asp.net
以前都是用aspnet_regiis -I 命令向IIS注册asp.net ,今天换了win8.1后竟然发现这招不好使了. 根据提示,需要用dism.exe来完成注册. 折腾一会儿后,问题最终解决: ...
- OAuth机制原理(开放授权机制)
1.简述 OAuth(Open Authorization,开放授权)是为用户资源的授权定义了一个安全.开放及简单的标准,第三方无需知道用户的账号及密码,就可获取到用户的授权信息,并且这是安全的. 国 ...
- mysql exceeded the 'max_questions' resource 记录
最近Hive Meta的 Mysql 常报错 'user' has exceeded the 'max_questions' resource (current value: 10000) 解决:调 ...
- FocusBI: SSIS 开发案例(原创)
关注微信公众号:FocusBI 查看更多文章:加QQ群:808774277 获取学习资料和一起探讨问题. <商业智能教程>pdf下载地址 链接:https://pan.baidu.com/ ...
- mysql数据库引擎InnoDB和MyISAM
一.Mysql锁分类 表级锁:开销小,加锁块:不会出现死锁,锁定粒度大,发生锁冲突的概率最高,并发度最低. 行级锁:开销大,加锁慢:会出现死锁:锁定粒度最小,发生锁冲突的概率最低,并发性也最高. 页面 ...
- 使用 Python 编写脚本并发布
使用 Python 编写脚本并发布 P1: 脚本 通常在 Linux 服务器上会遇到在命令行中输入命令的操作,而有些操作包含的命令数目较多或者其中的命令包含的参数较多,如果一个一个的敲命令的话就太麻烦 ...