博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ3517 翻硬币
阅读量:5283 次
发布时间:2019-06-14

本文共 1107 字,大约阅读时间需要 3 分钟。

  最后翻为0和1本质相同,只考虑一种。显然每个硬币最多翻一次。考虑设xi,j表示i,j位置的硬币是否翻,那么很容易就可以列出异或方程组。变量和方程都有n2个,那么解是唯一的,就不用考虑怎样最小化了。然而暴力高斯消元肯定是不行的。

  考虑将所有关于xi,k和xk,j的方程叠加,由于n是偶数,可以得到xi,j=ai,k^ak,j^ai,j (k=1~n)。于是就解出来了。

#include
#include
#include
#include
#include
#include
using namespace std;int read(){ int x=0,f=1;char c=getchar(); while (c<'0'||c>'9') { if (c=='-') f=-1;c=getchar();} while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar(); return x*f;}#define N 1010int n,a[N][N],s[2][N],ans;int main(){#ifndef ONLINE_JUDGE freopen("bzoj3517.in","r",stdin); freopen("bzoj3517.out","w",stdout); const char LL[]="%I64d\n";#else const char LL[]="%lld\n";#endif n=read(); for (int i=1;i<=n;i++) { char c=getchar(); while (c!='0'&&c!='1') c=getchar(); for (int j=1;j<=n;j++) a[i][j]=c^48,c=getchar(); } for (int i=1;i<=n;i++) for (int j=1;j<=n;j++) s[0][i]^=a[i][j],s[1][j]^=a[i][j]; for (int i=1;i<=n;i++) for (int j=1;j<=n;j++) ans+=s[0][i]^s[1][j]^a[i][j]; cout<

 

转载于:https://www.cnblogs.com/Gloid/p/9697180.html

你可能感兴趣的文章
EJBCA安装教程+postgresql+wildfly10
查看>>
(五十四)涂鸦的实现和截图的保存
查看>>
配置EditPlus使其可以编译运行java程序
查看>>
java中的占位符\t\n\r\f
查看>>
MySQL通过frm 和 ibd 恢复数据过程
查看>>
SRS源码——Listener
查看>>
Java面向对象抽象类案例分析
查看>>
对SPI、IIC、IIS、UART、CAN、SDIO、GPIO的解释
查看>>
Thymeleaf模板格式化LocalDatetime时间格式
查看>>
庖丁解“学生信息管理系统”
查看>>
Pyltp使用
查看>>
其他ip无法访问Yii的gii,配置ip就可以
查看>>
php做的一个简易爬虫
查看>>
x的x次幂的值为10,求x的近似值
查看>>
jquery获取html元素的绝对位置和相对位置的方法
查看>>
ios中webservice报文的拼接
查看>>
Power BI 报告的评论服务支持移动设备
查看>>
ACdream 1068
查看>>
HDU 2665 Kth number
查看>>
记叙在人生路上对你影响最大的三位老师
查看>>