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 二进制拆位 构造 最大匹配的更多相关文章

  1. 4.19 ABC F path pass i 容斥 树形dp

    LINK:path pass i 原本想了一个点分治 yy了半天 发现重复的部分还是很难减掉 况且统计答案的时候有点ex. (点了别人的提交记录 发现dfs就过了 于是yy了一个容斥 发现可以直接减掉 ...

  2. 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 ...

  3. 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 ...

  4. F - Qualification Rounds CodeForces - 868C 二进制

    F - Qualification Rounds CodeForces - 868C 这个题目不会,上网查了一下,发现一个结论就是如果是可以的,那么两个肯定可以满足. 然后就用二进制来压一下这个状态就 ...

  5. 输入一个A和B,,A<=B,A>=1,B<=pow(10,18)计算F=B!/A!结果的最后一位

    *************************************************************************代理运行函数,判断结果,进行输出*********** ...

  6. POJ 3422 Kaka's Matrix Travels(拆点+最大费用流)题解

    题意:小A从左上角走到右下角,每个格子都有一个价值,经过这个格子就把价值拿走,每次只能往下或往右走,问你走k次最多能拿多少价值的东西. 思路:这里有一个限制条件就是经过之后要把东西拿走,也就是每一格的 ...

  7. <2014 04 26> 《Coders at Work编程人生:15位软件先驱访谈录》

    什么是老派程序员?调试只用printf,关心数据结构,先整体或先局部,不知道OO.IDE.TDD.BDD等等为何物.Ken Thompson,Jamie Zawinski,Joe Armstrong, ...

  8. 九度OJ 1262:Sequence Construction puzzles(I)_构造全递增序列 (DP)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:118 解决:54 题目描述: 给定一个整数序列,请问如何去掉最少的元素使得原序列变成一个全递增的序列. 输入: 输入的第一行包括一个整数N( ...

  9. 九度oj 题目1262:Sequence Construction puzzles(I)_构造全递增序列

    题目描述: 给定一个整数序列,请问如何去掉最少的元素使得原序列变成一个全递增的序列. 输入: 输入的第一行包括一个整数N(1<=N<=10000). 接下来的一行是N个满足题目描述条件的整 ...

随机推荐

  1. if与switch(break穿透)

    ## if与switch(分支语句) ### 一.if...else if...else1.语法 if(条件表达式1){ 语句体1; }else if(条件表达式2){ 语句体2; }else{ 语句 ...

  2. CSS学习之选择器优先级与属性继承

    CSS学习之选择器优先级与属性继承 选择器优先级 其实选择器是具有优先级的,我们来看下面这一组案例: <!DOCTYPE html> <html lang="en" ...

  3. 题解:2018级算法第六次上机 C6-危机合约

    题目描述 样例: 实现解释: 没想到你也是个刀客塔之二维DP 知识点: 动态规划,多条流水线调度?可以看做一种流水线调度 坑点: 输入内容的调整(*的特殊判定),开头结尾的调整策略 从题意可知,要做的 ...

  4. 数据分析04 /基于pandas的DateFrame进行股票分析、双均线策略制定

    数据分析04 /基于pandas的DateFrame进行股票分析.双均线策略制定 目录 数据分析04 /基于pandas的DateFrame进行股票分析.双均线策略制定 需求1:对茅台股票分析 需求2 ...

  5. InnoDB表存储结构及keyring加密

    ibdata是InnoDB最重要的系统表空间文件,它记录了InnoDB的核心信息,包括事务系统信息.元数据信息,记录InnoDB change buffer的btree,防止数据损坏的double w ...

  6. mysql实现主从复制/主从同步

    业务场景 小公司业务代码存于一个服务器上,而这个服务器有的时候回宕机,导致业务停顿,造成影响.这个时候 就需要做高可用 两个ngix+两个tomcat+两个mysql实现高可用,避免单点问题.中间使用 ...

  7. bzoj3367[Usaco2004 Feb]The Big Game 球赛*

    bzoj3367[Usaco2004 Feb]The Big Game 球赛 题意: n只奶牛,每只支持两个球队中的一个,它们依次上车,上到一定程度可以开走这辆车并换下一辆继续上.要求一辆车上支持不同 ...

  8. python也能玩视频剪辑!moviepy操作记录总结

    前几篇文章咱们介绍了一下图片的处理方式,今天咱们说说视频的处理.python能够支持视频的处理么?当然是肯定的,人生苦读,我用python.万物皆可python. moviepy库安装 今天咱们需要使 ...

  9. P1776 宝物筛选

    题目: 正文: 啊,多重背包真恶心... 一开始我是把多重背包改成了01背包,然鹅我当时是直接1个1个的往后摞的... 参见以下代码: for(int i=1;i<=n;++i){//平平无奇的 ...

  10. java中实现无限层级的树形结构

    本文展示了两个实现方法的代码.两个代码的实现方法不同,代码2更为简单. 先看一下最后实现的结果: 最后结果-json 代码1: 实现过程: 1.传入一段json字符串 2.将字符串转换成对象存入节点列 ...