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个满足题目描述条件的整 ...
随机推荐
- USACO07 MAR Face The Right Way G
疫情当下,美帝又开始倒牛奶了,这一幕似曾相识啊~~~ 这个题目非常的应景,又是美国佬的奶牛 [题目地址] [一句话题意] N头牛排成一列1<=N<=5000.每头牛或者向前或者向后. 为了 ...
- [TZOJ] 平台训练-V1
日常训练 训练网址:http://www.tzcoder.cn/ 1001: 整数求和 描述求两个整数之和.输入输入数据只包括两个整数A和B.输出两个整数的和.样例输入1 2样例输出3题目来源TZOJ ...
- 二分查找&二叉排序树
首先我们先来复习一下二分查找的算法 对于正向序列的二分查找 递归实现: bool binary_search(vector<int> &sort_arry,int begin,in ...
- VSCode下,项识别为 cmdlet、函数、脚本文件或可运行程序的名称。
vscode下webpack错误:无法将“webpack”项识别为 cmdlet.函数.脚本文件或可运行程序的名称.请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次. 解决方法: 1.因为 ...
- linux09 /消息队列、saltstack工具
linux09 /消息队列.saltstack工具 目录 linux09 /消息队列.saltstack工具 1. 消息队列之rabbitmq 2. 云计算 3. 远程过程调用的实现:rpc 4. s ...
- Android 性能优化 ---- 启动优化
Android 性能优化 ---- 启动优化 1.为什么要进行启动优化 一款应用的第一印象很重要,第一印象往往决定了用户的去留.打开一款应用,如果速度很快,很顺畅,那么很容易让人觉得这款应用背后的技术 ...
- 数据源管理 | 搜索引擎框架,ElasticSearch集群模式
本文源码:GitHub·点这里 || GitEE·点这里 一.集群环境搭建 1.环境概览 ES版本6.3.2,集群名称esmaster,虚拟机centos7. 服务群 角色划分 说明 en-maste ...
- J.U.C体系进阶(一):juc-executors 执行器框架
Java - J.U.C体系进阶 作者:Kerwin 邮箱:806857264@qq.com 说到做到,就是我的忍道! 主要内容: juc-executors 执行器框架 juc-locks 锁框架 ...
- 基于Redis分布式锁的正确打开方式
分布式锁是在分布式环境下(多个JVM进程)控制多个客户端对某一资源的同步访问的一种实现,与之相对应的是线程锁,线程锁控制的是同一个JVM进程内多个线程之间的同步.分布式锁的一般实现方法是在应用服务器之 ...
- Websphere修改web.xml不生效的解决办法(转)
在websphere下部署了一个java工程后,如果修改了web.xml文件,重新启动这个java工程发现websphere并没有自动加载web.xml文件,即修改后的web.xml并不起作用,除非重 ...