Problem

SPOJ

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的更多相关文章

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

  2. SPOJ DQUERY D-query(主席树)

    题目 Source http://www.spoj.com/problems/DQUERY/en/ Description Given a sequence of n numbers a1, a2, ...

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

  4. 【填坑向】spoj COT/bzoj2588 Count on a tree

    这题是学主席树的时候就想写的,,, 但是当时没写(懒) 现在来填坑 = =日常调半天lca(考虑以后背板) 主席树还是蛮好写的,但是代码出现重复,不太好,导致调试的时候心里没底(虽然事实证明主席树部分 ...

  5. SPOJ bsubstr

    题目大意:给你一个长度为n的字符串,求出所有不同长度的字符串出现的最大次数. n<=250000 如:abaaa 输出: 4 2 1 1 1 spoj上的时限卡的太严,必须使用O(N)的算法那才 ...

  6. 【SPOJ 7258】Lexicographical Substring Search

    http://www.spoj.com/problems/SUBLEX/ 好难啊. 建出后缀自动机,然后在后缀自动机的每个状态上记录通过这个状态能走到的不同子串的数量.该状态能走到的所有状态的f值的和 ...

  7. 【SPOJ 1812】Longest Common Substring II

    http://www.spoj.com/problems/LCS2/ 这道题想了好久. 做法是对第一个串建后缀自动机,然后用后面的串去匹配它,并在走过的状态上记录走到这个状态时的最长距离.每匹配完一个 ...

  8. 【SPOJ 8222】Substrings

    http://www.spoj.com/problems/NSUBSTR/ clj课件里的例题 用结构体+指针写完模板后发现要访问所有的节点,改成数组会更方便些..于是改成了数组... 这道题重点是求 ...

  9. SPOJ GSS2 Can you answer these queries II

    Time Limit: 1000MS   Memory Limit: 1572864KB   64bit IO Format: %lld & %llu Description Being a ...

随机推荐

  1. Collection接口框架

    1. Collection接口 其主要的UML类图: Collection接口继承自Iterable接口.Iterable接口中定义了Iterable方法,该方法会返回一个迭代器,用于遍历合集中的元素 ...

  2. Liunx 和 Win中的软链接详解

    用过Linux的朋友都知道linux中有软链接的概念,可以通过ln命令创建到目录或文件的软链接,软链接的好处就是可以让一个目录或文件有多个入口但保持单一物理位置,方便应用和管理.    1.命令格式: ...

  3. (转)Spring用代码来读取properties文件

    转至http://www.cnblogs.com/Gyoung/p/5507063.html 我们都知道,Spring可以@Value的方式读取properties中的值,只需要在配置文件中配置org ...

  4. 题解 P1420 【最长连号】

    这个题过去的同学可以再来一题(P1567 统计天数): https://www.luogu.org/problemnew/show/P1567 是的,这个题其实也不是很难,就是前后比较,将天数压栈, ...

  5. P2812 校园网络【[USACO]Network of Schools加强版】

    题目背景 浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件.但是由于他们脑力劳动过多导致全身无力身体被♂掏♂空,他们来找你帮助他们. 题目描述 共 ...

  6. [您有新的未分配科技点]博弈论入门:被博弈论支配的恐惧(Nim游戏,SG函数)

    今天初步学习了一下博弈论……感觉真的是好精妙啊……希望这篇博客可以帮助到和我一样刚学习博弈论的同学们. 博弈论,又被称为对策论,被用于考虑游戏中个体的预测行为和实际行为,并研究他们的应用策略.(其实这 ...

  7. 关于qt中的tr()函数

    关于qt中的tr()函数 在论坛中漂,经常遇到有人遇到tr相关的问题.用tr的有两类人: (1)因为发现中文老出问题,然后搜索,发现很多人用tr,于是他也开始用tr (2)另一类人,确实是出于国际化的 ...

  8. BZOJ4033:[HAOI2015]树上染色——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=4033 有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将 ...

  9. 使用Unity5.1进行VR开发的配置(最新的未必是最好的!!!)

    随着Unity5.1的发布,之前的Oculus Rift和Gear VR 开发流程发生了巨大的变化,这也算是小白鼠们必须付出的代价了~ 那么Unity5.1和Oculus的整合究竟发生了哪些变化,对开 ...

  10. 洛谷U14200 Changing 题解 【杨辉三角】

    题目描述 有nnn盏灯环形排列,顺时针依次标号为1⋯n1\cdots n1⋯n.初始时刻为000,初始时刻第iii盏灯的亮灭aia_iai​给定,000表示灭,111表示亮.下一时刻每盏灯的亮灭取决于 ...