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. css两端对齐——div+css布局实现2端对齐的4种方法总结

    div+css布局实现2端对齐是我们网页排版中经常会使用到的,这篇文章将总结一下可以实现的方法: html结构 实现demo里面的div通过Css进行2端对齐. <div class=" ...

  2. java 中Object类中toString()的使用

    1. 当我们输出一个对象的引用时,实际上就是调用当前对象的toString() 2. Object类中toString()的定义: public String toString() { return ...

  3. POJ1852 Ants 题解

    题目 An army of ants walk on a horizontal pole of length l cm, each with a constant speed of 1 cm/s. W ...

  4. 蜂鸟E203系列——Linux开发工具

    欲观原文,请君移步 Vivado安装 vivado是运行工程的工具,所以必须安装 后台回复[vivado2017]可获取vivado 2017.4 | 后台回复[vivado2020]可获取vitis ...

  5. 数据可视化之DAX篇(五) 使用PowerBI的这两个函数,灵活计算各种占比

    https://zhuanlan.zhihu.com/p/57861350 计算个体占总体的比例是一个很常见的分析方式,它很简单,就是两个数字相除,但是当需要计算的维度.总体的范围发生动态变化时,如何 ...

  6. 微信小程序wx.switchTab跳转到tab页面后onLoad里面的方法不执行

    相信大家在做小程序的时候启动页跳转到tab首页会用到switchTab 但是在跳转后发现页面模块不全,后面console.log()后发现是onLoad里面的方法不执行 解决这种问题的方法页有很多中, ...

  7. 【设计模式】MVC、MVP、MVVM

    1.MVC模式: /** 模擬 Model, View, Controller */ var M = {}, V = {}, C = {}; /** Model 負責存放資料 */ M.data = ...

  8. 简易防止U盘中毒

    1.将U盘插入电脑,打开u盘 2.在U盘里面新建一个文本文档,将文本文档重命名autorun.inf保存完成. 3.为了防止误删次文件可以将属性设为影藏,就完成了.

  9. Maven如何利用父工程对版本进行统一管理

    项目开发中我们该怎么对项目依赖的版本进行统一管理呢 答:创建一个父级工程,让所有的业务模块都继承该父级工程,即所有的业务都为Module 在父级工程pom文件添加<dependencyManag ...

  10. java实现单链表的增删改以及排序

    使用java代码模拟单链表的增删改以及排序功能 代码如下: package com.seizedays.linked_list; public class SingleLinkedListDemo { ...