[ABC276Ex] Construct a Matrix
没有题解,所以来写一篇。
Description
构造一个 \(N\times N\) 的矩阵 \(A\),其中 \(A_{i,j}\in {0,1,2}\),要求同时满足 \(Q\) 条限制。
每条限制形如:给定 \(a,b,c,d,e\),要求 \(A\) 满足 \(\prod\limits_{i=a}^b\prod\limits_{j=c}^d A_{i,j} \equiv e\pmod 3\)。
Solution
为贴合原题,设 \((a,b,c,d)\) 表示左上角为 \((a,c)\),右下角为 \((b,d)\) 的矩形。
根据连乘的性质,若 \(e_i\) 不为 \(0\),则 \((a_i,b_i,c_i,d_i)\) 中任意 \(A_{i,j}\) 不能为 \(0\)。
而对于 \(e_i=0\),要求 \((a,b,c,d)\) 中至少一个是 \(0\)。那么对于不被 \(e_i\in\{1,2\}\) 限制的点,显然强制它们都为 \(0\) 一定不劣。如果这种方式依然不能满足所有 \(e_i=0\) 的限制,则无解。
现在我们已经确定哪些位置为 \(0\),只需要考虑不为 \(0\) 的位置与 \(e_i\in\{1,2\}\) 的限制。而 \(A_{i,j}=1\) 对矩阵积同样没有影响,矩阵积模 \(3\) 的值只与 \(A_{i,j}=2\) 的数量有关。
简单找规律(?)可以发现,\(2\) 的奇数次幂 \(\bmod 3\) 的值为 \(2\),偶数次幂 \(\bmod 3\) 的值为 \(1\)。
考虑把每个 \(A_{i,j}\) 设为未知数解方程。
令 \(x_{i,j}\) 的值 \(0,1\) 对应 \(A_{i,j}\) 的 \({1,2}\),那么会得到 \(Q\) 组方程,形如:
\]
未知数个数为 \(n^2\),直接高斯消元复杂度不能接受。
重定义 \(x_{a,b}=\sum\limits_{i=1}^a\sum\limits_{j=1}^b A_{i,j} \pmod 2\),则每个方程可以写成:
\]
这样每次询问最多会产生 \(4\) 个未知数,未知数个数降为 \(4Q\)。
发现系数只有 \(0,1\),使用 bitset 优化,复杂度降为 \(O(\frac{Q^3}{w})\),可以通过。
Code
通过研读部分提交记录才得以大致理解做法,代码可能有参考。
#include<bits/stdc++.h>
#define il inline
using namespace std;
il int read()
{
int xr=0,F=1; char cr;
while(cr=getchar(),cr<'0'||cr>'9') if(cr=='-') F=-1;
while(cr>='0'&&cr<='9')
xr=(xr<<3)+(xr<<1)+(cr^48),cr=getchar();
return xr*F;
}
const int N=2005;
int n,q;
struct node{
int a,b,c,d,e;
};
vector<node> t;
bitset<(N<<2)> now,a[N<<2];
int id[N][N],s[N][N],tot;
il void add(int x,int y)
{
if(!x||!y) return;
if(!id[x][y]) id[x][y]=++tot;
now[id[x][y]]=1;
}
bool flag;
il void ins()
{
for(int i=1;i<=tot;i++)
{
if(!now[i]) continue;
if(!a[i][i]) {a[i]=now;return;}
now^=a[i];
}
if(now[0]) {printf("No\n");flag=1;}
}
int ans[N][N];
int main()
{
n=read(),q=read();
for(int i=1;i<=q;i++)
{
int a=read(),b=read(),c=read(),d=read(),e=read();
if(!e) t.push_back({a,b,c,d,e});
else
{
s[a][c]++,s[b+1][d+1]++,s[b+1][c]--,s[a][d+1]--;
now.reset();
add(a-1,c-1),add(b,d),add(a-1,d),add(b,c-1);
if(e==2) now[0]=1; ins();
if(flag) return 0;
}
}
//for(int i=1;i<=tot;i++,cout<<endl) for(int j=1;j<=n+1;j++) cout<<a[i][j]<<" ";
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
s[i][j]=s[i-1][j]+s[i][j-1]-s[i-1][j-1]+s[i][j];
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) s[i][j]=!s[i][j];
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) s[i][j]=s[i][j-1]+s[i-1][j]-s[i-1][j-1]+s[i][j];
for(auto u:t)
if(s[u.b][u.d]-s[u.b][u.c-1]-s[u.a-1][u.d]+s[u.a-1][u.c-1]==0) {printf("No\n");return 0;}
now.reset();
for(int i=tot;i;i--)
{
if(!a[i][i]) continue;
now[i]=((now&a[i]).count()&1)^(a[i][0]);
}
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) if(id[i][j]) ans[i][j]=now[id[i][j]];
for(int i=n;i;i--) for(int j=n;j;j--)
ans[i][j]=ans[i][j]^ans[i-1][j]^ans[i][j-1]^ans[i-1][j-1];
printf("Yes\n");
for(int i=1;i<=n;i++,printf("\n"))
for(int j=1;j<=n;j++)
{
if(s[i][j]-s[i-1][j]-s[i][j-1]+s[i-1][j-1]) printf("0 ");
else if(ans[i][j]) printf("2 ");
else printf("1 ");
}
return 0;
}
[ABC276Ex] Construct a Matrix的更多相关文章
- FZU 1911 Construct a Matrix
题目链接:Construct a Matrix 题意:构造一个矩阵,要求矩阵的每行每列的和都不相同.矩阵的边长是前n项斐波那契的和. 思路:由sn = 2*(fn-1)+(fn-2)-1,只要知道第n ...
- fzu 1911 Construct a Matrix(矩阵快速幂+规律)
题目链接:fzu 1911 Construct a Matrix 题目大意:给出n和m,f[i]为斐波那契数列,s[i]为斐波那契数列前i项的和.r = s[n] % m.构造一个r * r的矩阵,只 ...
- fzu 1911 C. Construct a Matrix
C. Construct a Matrix Time Limit: 1000ms Case Time Limit: 1000ms Memory Limit: 32768KB Special Judge ...
- Construct a Matrix (矩阵快速幂+构造)
There is a set of matrixes that are constructed subject to the following constraints: 1. The matrix ...
- <转载> OpenGL Projection Matrix
原文 OpenGL Projection Matrix Related Topics: OpenGL Transformation Overview Perspective Projection Or ...
- Palindromic Matrix
Palindromic Matrix time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
- Codeforces Round #540 (Div. 3) C. Palindromic Matrix 【暴力】
任意门:http://codeforces.com/contest/1118/problem/C C. Palindromic Matrix time limit per test 2 seconds ...
- AP(affinity propagation)研究
待补充…… AP算法,即Affinity propagation,是Brendan J. Frey* 和Delbert Dueck于2007年在science上提出的一种算法(文章链接,维基百科) 现 ...
- 最喜欢的算法(们) - Levenshtein distance
String Matching: Levenshtein distance Purpose: to use as little effort to convert one string into th ...
- 利用奇异值分解(SVD)简化数据
特征值与特征向量 下面这部分内容摘自:强大的矩阵奇异值分解(SVD)及其应用 特征值分解和奇异值分解在机器学习领域都是属于满地可见的方法.两者有着很紧密的关系,在接下来会谈到,特征值分解和奇异值分解的 ...
随机推荐
- 吴恩达优化算法 (Optimization algorithms)笔记
Mini-batch 梯度下降(Mini-batch gradient descent) 使用batch梯度下降法,一次遍历训练集只能让你做一个梯度下降,使用mini-batch梯度下降法,一次遍历训 ...
- 即构发布 LCEP 产品「RoomKit」 ,实现房间内0代码接入
2021年2月5日,即构科技正式发布全新形态「低代码互动平台」(Low-code Engagement Platform,简称LCEP)产品「RoomKit」. RoomKit定位为低代码互动平台(L ...
- Nginx配置网站默认https
Nginx配置网站默认https 一.安装Nginx yum install nginx -y 二.修改nginx.conf vim /etc/nginx/nginx.conf 配置80转443 配置 ...
- JAVA小白找工作必备建议
如果您是一名刚入门的JAVA小白,正在寻求工作机会,那么恭喜您来对地方!本文将为您提供一些建议,帮助您在求职过程中更好地展现自己的优势和准备迎接新的挑战. 1.基础知识打牢 在找工作前,务必确保您对J ...
- struct 结构体分析
struct分析 1.无成员的空结构体size为 1byte 2.通过/zp可以调整对齐值,默认是8字节 //设编译对齐设定值为Zp //设成员变量的类型为 member type //设成员变量在结 ...
- FAQ:zabbix 频繁丢失数据问题分析处理
问题描述 在grafana上看到历史数据的绘图断断续续. 问题分析 1 性能瓶颈 一开始以为是哪里的性能遇到瓶颈,把服务器和zabbix的监控数据看了一遍,各个指标都没有问题. 2 上网百度 没有找到 ...
- excel 启用迭代计算
迭代,即计算程序中一组指令的重复.在Excel中有些公式需要启用迭代计算,才能正常运算. 注:公式直接或间接引用自身单元格,会导致计算结果不正确,可以尝试使用该方法解决.所愿单元格的初始值都为0. 参 ...
- Hi3798MV200 恩兔N2 NS-1 (三): 制作 Ubuntu rootfs
目录 Hi3798MV200 恩兔N2 NS-1 (一): 设备介绍和刷机说明 Hi3798MV200 恩兔N2 NS-1 (二): HiNAS海纳思使用和修改 Hi3798MV200 恩兔N2 NS ...
- 【RocketMQ】消息的发送
RocketMQ是通过DefaultMQProducer进行消息发送的,它实现了MQProducer接口,MQProducer接口中定义了消息发送的方法,方法主要分为三大类: send同步进行消息发送 ...
- Luckysheet:一个纯前端的excel在线表格
最近因为项目要求,需要在页面上添加一个在线编辑excel的功能,因此只能在网上找有没有直接用的插件,最后很幸运的是幸好找到了一个 ----luckysheet. 这个是从luckysheet官网上找的 ...