4.26 ABC F I hate Matrix Construction 二进制拆位 构造 最大匹配
LINK:I hate Matrix Construction
心情如题目名称。
主要说明一下构造的正确性。
准确来说这道题困扰我很久。
容易发现可以拆位构造。
这样题目中的条件也比较容易使用。
最后等价于每一行每一列有一个 当前行/列有一个1或者0的限制。
考虑直接进行构造。
容易发现这类似于最大匹配 尝试利用最大匹配来做 不过这样的话时间复杂度会爆掉且不好写。
可以观察到一个性质 一个点只会为一行或者一列提供贡献 如果行列的需求一样那么这个点直接放即最优。
最后问题变成了 有一些没有放值得位置 要求合理的放值满足一些 行或列的限制 且这些位置最多只会满足行列中的一种的约束。
关于剩下的条件 是否存在增广路的问题:如果当且列放了值影响到行的最优决策了 首先点不是共用的 且这个行会影响到其他列。
如果存在一条增广路 但是考虑到 此时的列 和其他的列是相同的 所以当且列也直接存在增广路 所以影响关系是不存在的。
综上 直接进行构造 因为不存在类似于最大匹配的增广路存在。
一种比较简单的构造方法:
先让剩下的全部变成0 对于1找0的存在 看能否更替即可。
最后注意再check一下 可能变得不合法了。
写法是借鉴别人的 我也同时意识到 随便写代码复杂度很高。
const ll MAXN=510;
int n,cc;
int s[MAXN],t[MAXN];
ull v[MAXN],u[MAXN];
int b[MAXN][MAXN];
int r[MAXN][2],c[MAXN][2];
ull a[MAXN][MAXN];
inline int solve()
{
rep(0,63,k)
{
memset(b,-1,sizeof(b));
memset(c,0,sizeof(c));
memset(r,0,sizeof(r));
rep(1,n,i)
{
int x=u[i]&1;
if(s[i]==x)continue;
rep(1,n,j)if(b[i][j]!=-1&&b[i][j]!=x)return 0;
else b[i][j]=x;
}
rep(1,n,i)
{
int x=v[i]&1;
if(t[i]==x)continue;
rep(1,n,j)if(b[j][i]!=-1&&b[j][i]!=x)return 0;
else b[j][i]=x;
}
rep(1,n,i)rep(1,n,j)
{
if((u[i]&1)==(v[j]&1))b[i][j]=(u[i]&1);
if(b[i][j]==-1)b[i][j]=0;
++r[i][b[i][j]];
++c[j][b[i][j]];
}
rep(1,n,i)
if(s[i]&&(u[i]&1))
{
if(r[i][1])continue;
rep(1,n,j)
{
if(!t[j]&&!(v[j]&1)&&c[j][0]>1)
{
b[i][j]=1;
--c[j][0];--r[i][0];
++c[j][1];++r[i][1];
break;
}
}
}
rep(1,n,i)
{
if(t[i]&&(v[i]&1))
{
if(c[i][1])continue;
rep(1,n,j)
{
if(!s[j]&&!(u[j]&1)&&r[j][0]>1)
{
b[j][i]=1;
--r[j][0];--c[i][0];
++r[j][1];++c[i][1];
break;
}
}
}
}
rep(1,n,i)
{
if((u[i]&1)&&!s[i]&&r[i][1]!=n)return 0;
if(!(u[i]&1)&&s[i]&&r[i][0]!=n)return 0;
if(!(v[i]&1)&&t[i]&&c[i][0]!=n)return 0;
if((v[i]&1)&&!t[i]&&c[i][1]!=n)return 0;
if((u[i]&1)==s[i]&&!s[i]&&!r[i][0])return 0;
if((u[i]&1)==s[i]&&s[i]&&!r[i][1])return 0;
if((v[i]&1)==t[i]&&t[i]&&!c[i][1])return 0;
if((v[i]&1)==t[i]&&!t[i]&&!c[i][0])return 0;
}
rep(1,n,i)rep(1,n,j)if(b[i][j])a[i][j]=a[i][j]|(1ull<<k);
rep(1,n,i)u[i]>>=1,v[i]>>=1;
}
return 1;
}
signed main()
{
freopen("1.in","r",stdin);
gt(n);
rep(1,n,i)gt(s[i]);
rep(1,n,i)gt(t[i]);
rep(1,n,i)scanf("%llu",&u[i]);
rep(1,n,i)scanf("%llu",&v[i]);
if(!solve())puts("-1");
else rep(1,n,i)rep(1,n,j)printf("%llu%c",a[i][j],j!=n?' ':'\n');
return 0;
}
4.26 ABC F I hate Matrix Construction 二进制拆位 构造 最大匹配的更多相关文章
- 4.19 ABC F path pass i 容斥 树形dp
LINK:path pass i 原本想了一个点分治 yy了半天 发现重复的部分还是很难减掉 况且统计答案的时候有点ex. (点了别人的提交记录 发现dfs就过了 于是yy了一个容斥 发现可以直接减掉 ...
- Code force-CodeCraft-20 (Div. 2) D. Nash Matrix 详解(DFS构造)
D. Nash Matrix time limit per test2 seconds memory limit per test256 megabytes inputstandard input o ...
- Vasya And The Matrix CodeForces - 1016D (思维+构造)
Now Vasya is taking an exam in mathematics. In order to get a good mark, Vasya needs to guess the ma ...
- F - Qualification Rounds CodeForces - 868C 二进制
F - Qualification Rounds CodeForces - 868C 这个题目不会,上网查了一下,发现一个结论就是如果是可以的,那么两个肯定可以满足. 然后就用二进制来压一下这个状态就 ...
- 输入一个A和B,,A<=B,A>=1,B<=pow(10,18)计算F=B!/A!结果的最后一位
*************************************************************************代理运行函数,判断结果,进行输出*********** ...
- POJ 3422 Kaka's Matrix Travels(拆点+最大费用流)题解
题意:小A从左上角走到右下角,每个格子都有一个价值,经过这个格子就把价值拿走,每次只能往下或往右走,问你走k次最多能拿多少价值的东西. 思路:这里有一个限制条件就是经过之后要把东西拿走,也就是每一格的 ...
- <2014 04 26> 《Coders at Work编程人生:15位软件先驱访谈录》
什么是老派程序员?调试只用printf,关心数据结构,先整体或先局部,不知道OO.IDE.TDD.BDD等等为何物.Ken Thompson,Jamie Zawinski,Joe Armstrong, ...
- 九度OJ 1262:Sequence Construction puzzles(I)_构造全递增序列 (DP)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:118 解决:54 题目描述: 给定一个整数序列,请问如何去掉最少的元素使得原序列变成一个全递增的序列. 输入: 输入的第一行包括一个整数N( ...
- 九度oj 题目1262:Sequence Construction puzzles(I)_构造全递增序列
题目描述: 给定一个整数序列,请问如何去掉最少的元素使得原序列变成一个全递增的序列. 输入: 输入的第一行包括一个整数N(1<=N<=10000). 接下来的一行是N个满足题目描述条件的整 ...
随机推荐
- if与switch(break穿透)
## if与switch(分支语句) ### 一.if...else if...else1.语法 if(条件表达式1){ 语句体1; }else if(条件表达式2){ 语句体2; }else{ 语句 ...
- CSS学习之选择器优先级与属性继承
CSS学习之选择器优先级与属性继承 选择器优先级 其实选择器是具有优先级的,我们来看下面这一组案例: <!DOCTYPE html> <html lang="en" ...
- 题解:2018级算法第六次上机 C6-危机合约
题目描述 样例: 实现解释: 没想到你也是个刀客塔之二维DP 知识点: 动态规划,多条流水线调度?可以看做一种流水线调度 坑点: 输入内容的调整(*的特殊判定),开头结尾的调整策略 从题意可知,要做的 ...
- 数据分析04 /基于pandas的DateFrame进行股票分析、双均线策略制定
数据分析04 /基于pandas的DateFrame进行股票分析.双均线策略制定 目录 数据分析04 /基于pandas的DateFrame进行股票分析.双均线策略制定 需求1:对茅台股票分析 需求2 ...
- InnoDB表存储结构及keyring加密
ibdata是InnoDB最重要的系统表空间文件,它记录了InnoDB的核心信息,包括事务系统信息.元数据信息,记录InnoDB change buffer的btree,防止数据损坏的double w ...
- mysql实现主从复制/主从同步
业务场景 小公司业务代码存于一个服务器上,而这个服务器有的时候回宕机,导致业务停顿,造成影响.这个时候 就需要做高可用 两个ngix+两个tomcat+两个mysql实现高可用,避免单点问题.中间使用 ...
- bzoj3367[Usaco2004 Feb]The Big Game 球赛*
bzoj3367[Usaco2004 Feb]The Big Game 球赛 题意: n只奶牛,每只支持两个球队中的一个,它们依次上车,上到一定程度可以开走这辆车并换下一辆继续上.要求一辆车上支持不同 ...
- python也能玩视频剪辑!moviepy操作记录总结
前几篇文章咱们介绍了一下图片的处理方式,今天咱们说说视频的处理.python能够支持视频的处理么?当然是肯定的,人生苦读,我用python.万物皆可python. moviepy库安装 今天咱们需要使 ...
- P1776 宝物筛选
题目: 正文: 啊,多重背包真恶心... 一开始我是把多重背包改成了01背包,然鹅我当时是直接1个1个的往后摞的... 参见以下代码: for(int i=1;i<=n;++i){//平平无奇的 ...
- java中实现无限层级的树形结构
本文展示了两个实现方法的代码.两个代码的实现方法不同,代码2更为简单. 先看一下最后实现的结果: 最后结果-json 代码1: 实现过程: 1.传入一段json字符串 2.将字符串转换成对象存入节点列 ...