SPOJ JZPLIT
Problem
Solution
考虑任意一个作为矩阵四个角的位置
\(r_i \oplus c_j\oplus a_{i,j}\oplus x_{i,j}=0\)
\(r_i \oplus c_{j+1}\oplus a_{i,j+1}\oplus x_{i,j+1}=0\)
\(r_{i+1}\oplus c_j\oplus a_{i+1,j}\oplus x_{i+1,j}=0\)
\(r_{i+1}\oplus c_{j+1}\oplus a_{i+1,j+1}\oplus x_{i+1,j+1}=0\)
\(a_{i,j}\oplus a_{i,j+1}\oplus a_{i+1,j}\oplus a_{i+1,j+1}\oplus x_{i,j}\oplus x_{i,j+1}\oplus x_{i+1,j}\oplus x_{i+1,j+1}=0\)
则只需要解出第一行第一列的操作方法就可以表示其他格子的操作方法。
未知的状态数就减少到\(O(n+m-1)\)。对于所有第一行第一列的格子列方程,即这行这列的所有操作异或后等于当前状态,然后bitset优化即可。
时间复杂度\(O(\frac {(n+m)^3} {32})\),注意卡常。
Code
#pragma GCC optimize("no-stack-protector")
#pragma GCC optimize("Ofast")
#pragma GCC optimize(3)
#include <cstdio>
#include <bitset>
using namespace std;
typedef long long ll;
template <typename Tp> inline int getmin(Tp &x,Tp y){return y<x?x=y,1:0;}
template <typename Tp> inline int getmax(Tp &x,Tp y){return y>x?x=y,1:0;}
template <typename Tp> inline void read(Tp &x)
{
x=0;int f=0;char ch=getchar();
while(ch!='-'&&(ch<'0'||ch>'9')) ch=getchar();
if(ch=='-') f=1,ch=getchar();
while(ch>='0'&&ch<='9') x=x*10+ch-'0',ch=getchar();
if(f) x=-x;
}
int n,m,a[1010][1010],b[2010][2010],ans[1010][1010];
char s[1010];
bitset<2010> x[2010];
inline void calc(int i,int j,int id)
{
b[id][1]^=1;b[id][j]^=1;b[id][i+m-1]^=1;
b[id][n+m]^=a[1][1]^a[1][j]^a[i][1]^a[i][j];
}
void gauss()
{
int k;
for(int i=1;i<n+m;i++)
{
for(k=i;k<n+m;k++)
if(x[k][i]) break;
if(k>=n+m) continue;
if(k^i) swap(x[i],x[k]);
for(int j=1;j<n+m;j++)
if(i^j&&x[j][i])
x[j]^=x[i];
}
}
int main()
{
read(n);read(m);
for(int i=1;i<=n;i++)
{
scanf("%s",s+1);
for(int j=1;j<=m;j++) a[i][j]=(s[j]=='1');
}
for(int i=1;i<n+m;i++) b[i][i]=1;
for(int i=1;i<n+m;i++) b[1][i]=1;
b[1][n+m]=a[1][1];
//the first eq
for(int i=2;i<=m;i++)
{
b[i][n+m]=a[1][i];
for(int j=1;j<=m;j++) b[i][j]=1;
}
for(int i=2;i<=n;i++)
{
b[i+m-1][n+m]=a[i][1];b[i+m-1][1]=1;
for(int j=m+1;j<n+m;j++) b[i+m-1][j]=1;
}
for(int i=2;i<=n;i++)
for(int j=2;j<=m;j++)
{
calc(i,j,j);
calc(i,j,i+m-1);
}
for(int i=1;i<n+m;i++)
for(int j=1;j<=n+m;j++)
if(b[i][j])
x[i].set(j);
gauss();
for(int i=1;i<=m;i++) ans[1][i]=x[i][n+m];
for(int i=2;i<=n;i++) ans[i][1]=x[i+m-1][n+m];
for(int i=1;i<=n;i++,putchar('\n'))
for(int j=1;j<=m;j++)
{
if(i>1&&j>1)
ans[i][j]=a[1][1]^a[i][1]^a[1][j]^a[i][j]^ans[1][1]^ans[i][1]^ans[1][j];
printf("%d",ans[i][j]);
}
return 0;
}
SPOJ JZPLIT的更多相关文章
- BZOJ 2588: Spoj 10628. Count on a tree [树上主席树]
2588: Spoj 10628. Count on a tree Time Limit: 12 Sec Memory Limit: 128 MBSubmit: 5217 Solved: 1233 ...
- SPOJ DQUERY D-query(主席树)
题目 Source http://www.spoj.com/problems/DQUERY/en/ Description Given a sequence of n numbers a1, a2, ...
- SPOJ GSS3 Can you answer these queries III[线段树]
SPOJ - GSS3 Can you answer these queries III Description You are given a sequence A of N (N <= 50 ...
- 【填坑向】spoj COT/bzoj2588 Count on a tree
这题是学主席树的时候就想写的,,, 但是当时没写(懒) 现在来填坑 = =日常调半天lca(考虑以后背板) 主席树还是蛮好写的,但是代码出现重复,不太好,导致调试的时候心里没底(虽然事实证明主席树部分 ...
- SPOJ bsubstr
题目大意:给你一个长度为n的字符串,求出所有不同长度的字符串出现的最大次数. n<=250000 如:abaaa 输出: 4 2 1 1 1 spoj上的时限卡的太严,必须使用O(N)的算法那才 ...
- 【SPOJ 7258】Lexicographical Substring Search
http://www.spoj.com/problems/SUBLEX/ 好难啊. 建出后缀自动机,然后在后缀自动机的每个状态上记录通过这个状态能走到的不同子串的数量.该状态能走到的所有状态的f值的和 ...
- 【SPOJ 1812】Longest Common Substring II
http://www.spoj.com/problems/LCS2/ 这道题想了好久. 做法是对第一个串建后缀自动机,然后用后面的串去匹配它,并在走过的状态上记录走到这个状态时的最长距离.每匹配完一个 ...
- 【SPOJ 8222】Substrings
http://www.spoj.com/problems/NSUBSTR/ clj课件里的例题 用结构体+指针写完模板后发现要访问所有的节点,改成数组会更方便些..于是改成了数组... 这道题重点是求 ...
- SPOJ GSS2 Can you answer these queries II
Time Limit: 1000MS Memory Limit: 1572864KB 64bit IO Format: %lld & %llu Description Being a ...
随机推荐
- 自动化生成html报告
package Utils; import java.io.File; import java.util.Date; import org.apache.commons.lang3.time.Date ...
- Golang的第一个程序-Hello, World !
安装Golang: 1. 下载安装包 https://golang.google.cn/dl/ 我这里使用压缩包,下载后解压到D盘(自定义). 2. 添加环境变量:把解压后的bin目录添加到环境变量中 ...
- 【刷题】BZOJ 3926 [Zjoi2015]诸神眷顾的幻想乡
Description 幽香是全幻想乡里最受人欢迎的萌妹子,这天,是幽香的2600岁生日,无数幽香的粉丝到了幽香家门前的太阳花田上来为幽香庆祝生日. 粉丝们非常热情,自发组织表演了一系列节目给幽香看. ...
- 【BZOJ1416/1498】【NOI2006】神奇的口袋(数论,概率)
[BZOJ1416/1498][NOI2006]神奇的口袋(数论,概率) 题面 BZOJ1416 BZOJ1498 洛谷 题面都是图片形式是什么鬼.. 题解 考虑以下性质 1.\(x[1],x[2]. ...
- C++ 指针[转+原创]
要搞清一个指针需要搞清指针的四方面的内容:指针的类型,指针所指向的类型,指针的值或者叫指针所指向的内存区,还有指针本身所占据的内存区. 指针的类型 从语法的角度看,你只要把指针声明语句里的指针名字去掉 ...
- SQL注入(SQL Injection)案例和防御方案
sql注入(SQL Injection):就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令. SQL注入攻击的主要危害包括:非法读取.篡 ...
- Codeforces 744C. Hongcow Buys a Deck of Cards(状压DP)
这题的难点在于状态的设计 首先显然是个状压,需要一维表示卡的状态,另一维如果设计成天数,难以知道当前的钱数,没法确定是否能够购买新的卡,如果设计成钱数,会发现状态数过多,空间与时间都无法承受.但是可以 ...
- Codeforces Round #441 Div. 2题解
比赛的时候E调了好久...F没时间写T T A:直接走到短的路上来回走就好了 #include<iostream> #include<cstring> #include< ...
- 【数论】数论进阶-Preknowledge
数论进阶-Preknowledge 参考资料:洛谷网校2018夏季省选基础班SX-3数论进阶课程及课件 一.整除与取整除法 1.1 定义 1.整除 \(\forall~x,y~\in~Z^+,\) 若 ...
- dTree 动态生成树
http://luohua.iteye.com/blog/451453 dTree 主页:http://destroydrop.com/javascripts/tree/ dTree是个很方便在页面生 ...