16年北京站A题 真的难啊..

题意:

定义和谐矩阵 就是每个元素和上下左右的xor值=0

输出一个超大数 然后最多800个询问 求字典序第k小的和谐矩阵 x y位置上的数

题解:

首先这个超大数的范围其实给了提示 $2^{800}$ 我们刚好想到枚举第一行 就有这么多种

确实 我们很容易发现 枚举了第一行之后 整个矩阵就可以算出来了

然后现在就要引出一个子题 P3164

关于这个子题 在2020年5月份之前洛谷上的题解都不是太正的做法

正确做法是 把第一行的每个元素当作一个未知数 然后可以推到第n行

用第n行是和谐矩阵元素的关系得到m个方程式 高斯消元解之

我们再回到这个题 我们同样可以用这样的方法 高斯消元解之 然后我们开始写了!

先用高斯消元解出系数 然后把10进制的大数转化为二进制 为什么这题有第k小呢 因为我们解出了自由元啊!

如果自由元所能提供的解 小于k就直接无解了

然后我们惊奇的发现 字典序第k小的二进制刚好就是这个问题自由元的解 一一对应填进去就行了

然后这样交上去会得到 WA!!

为什么呢? 因为我们正常解出的自由元 所对应的未知数 实际上是可以提前更换位置的啊!

那么我们可以把自由元放在最前面 以得到字典序最小

#include <stdio.h>
#include <bits/stdc++.h>
#include <iostream>
#include <algorithm>
#include <bitset>
using namespace std;
const int MAXN = 805; int n, m, q, x, y, len, rk, blen;
bitset<MAXN> a[MAXN][MAXN];
bitset<MAXN> b[MAXN];
int ans[MAXN];
int fr[MAXN];
char s[MAXN];
int t[MAXN], bit[MAXN << 3]; int dx[] = {-1, -1, -1, -2};
int dy[] = {-1, 0, 1, 0}; bool check(int x, int y) {
if(x >= 1 && x <= n && y >= 1 && y <= m) return true;
return false;
} void gauss() {
rk = 0;
for(int i = 1, now = m; i <= m && now; now--) {
for(int j = i; j <= m; j++) {
if(b[j][now]) {
std::swap(b[j], b[i]);
break;
}
}
if(!b[i][now]) {
//fr[now] = 1;
continue;
}
for(int j = i + 1; j <= m; j++) {
if(b[j][now]) {
b[j] ^= b[i];
}
}
fr[now] = i;
i++; rk++;
}
} void decode() {
blen = 0;
int llen = strlen(s + 1); memset(bit, 0, sizeof(bit));
for(int i = 1; i <= llen; i++) t[i] = s[llen - i + 1] - '0';
t[1]--;
int now = 1; while(t[now] < 0) t[now] += 10, now++, t[now]--;
while(llen && !t[llen]) llen--; while(llen) {
if(t[1] & 1) bit[++blen] = 1;
else bit[++blen] = 0; int res = 0;
for(int i = llen; i >= 1; i--) {
int tmp = (t[i] + res * 10) / 2;
res = (t[i] + res * 10) % 2;
t[i] = tmp;
}
while(llen && !t[llen]) llen--;
}
} void get() {
blen = max(blen, m - rk);
memset(ans, 0, sizeof(ans));
for(int i = 1; i <= m; i++) if(!fr[i]) ans[i] = bit[blen--];
for(int i = 1; i <= m; i++) {
if(fr[i])
for(int j = i - 1; j; j--) {
if(b[fr[i]][j]) ans[i] ^= ans[j];
}
}
} int main() {
while(~scanf("%d%d%d", &n, &m, &q)) {
memset(fr, 0, sizeof(fr));
for(int i = 1; i <= m; i++) b[i].reset();
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++)
a[i][j].reset();
for(int i = 1; i <= m; i++) a[1][i][i] = 1; for(int i = 2; i <= n; i++) {
for(int j = 1; j <= m; j++) {
for(int k = 0; k < 4; k++) {
int nx = i + dx[k];
int ny = j + dy[k];
if(check(nx, ny)) a[i][j] ^= a[nx][ny];
}
}
}
for(int i = 1; i <= m; i++) b[i] = a[n][i];
for(int i = 1; i <= m; i++) {
if(n - 1 >= 1) b[i] ^= a[n - 1][i];
if(i - 1 >= 1) b[i] ^= a[n][i - 1];
if(i + 1 <= m) b[i] ^= a[n][i + 1];
}
gauss();
//for(int i = 1; i <= m; i++) cout << fr[i] << " "; puts(""); //cout << m - rk << " ??" << endl;
for(int cas = 1; cas <= q; cas++) {
scanf("%s%d%d", s + 1, &x, &y);
decode();
//cout << "blen =" << blen <<endl;
if(m - rk < blen) printf("?");
else {
get();
/*
for(int i = 1; i <= n; i++) {
for(int j = 1; j <= m; j++) {
int res = 0;
for(int k = 1; k <= m; k++)
if(a[i][j][k]) res ^= ans[k];
printf("%d ", res);
}
puts("");
}*/ int res = 0;
for(int i = 1; i <= m; i++) if(a[x][y][i]) res ^= ans[i];
printf("%d", res);
}
}
puts("");
}
return 0;
}
/*
3 5 10
0 0 0 2 1
1 1 1
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0
2 1 1
0 0 1 1 1
0 1 0 1 0
1 1 1 0 0
3 1 1
0 1 0 0 0
1 1 1 0 0
0 0 0 1 0
4 1 1
0 1 1 0 1
1 0 0 0 1
1 0 1 1 0
5 1 1
1 0 0 0 0
1 1 0 0 0
1 0 1 0 0
6 1 1
1 0 1 1 0
1 0 0 0 1
0 1 1 0 1
7 1 1
1 1 0 0 0
0 0 1 0 0
1 0 1 1 0
8 1 1
1 1 1 0 0
0 1 0 1 0
0 0 1 1 1
*/

Hiho1422 Harmonic Matrix Counter (高斯消元)的更多相关文章

  1. 算法竞赛进阶指南0x35高斯消元与线性空间

    高斯消元 目录 高斯消元 ACWing207. 球形空间产生器(点击访问) 求解思路 代码 ACWing208. 开关问题(点击访问) 思路 代码 总结 欣赏 线性空间 定义 ACWing209. 装 ...

  2. Matrix 高斯消元Gaussian elimination 中的complete pivoting和partial pivoting

    首先科普下Pivoting的含义 一般翻译为“主元”,在对矩阵做某种算法时,首先进行的部分元素.在线性规划的单纯形法中常见.wiki的解释如下:Pivot element(the first elem ...

  3. UVALive 7138 The Matrix Revolutions(Matrix-Tree + 高斯消元)(2014 Asia Shanghai Regional Contest)

    题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=6 ...

  4. UVALive 6449 IQ Test --高斯消元?

    题意:给你一串数字,问这串数字符合f[n] = a*f[n-1],f[n] = a*f[n-1]+b*f[n-2],f[n] = a*f[n-1]+b*f[n-2]+c*f[n-3]这几个方程中的哪个 ...

  5. USACO 3.2 ratios 高斯消元

    题目原意很简单,就是解一个三元一次方程组 直接高斯消元解方程组,枚举最后一列的倍数(k) 注意double的精度,有很多细节需要处理 /* PROB:ratios LANG:C++ */ #inclu ...

  6. HDU 5833 Zhu and 772002 (高斯消元)

    Zhu and 772002 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5833 Description Zhu and 772002 are b ...

  7. 【高斯消元】兼 【期望dp】例题

    [总览] 高斯消元基本思想是将方程式的系数和常数化为矩阵,通过将矩阵通过行变换成为阶梯状(三角形),然后从小往上逐一求解. 如:$3X_1 + 2X_2 + 1X_3 = 3$ $           ...

  8. BZOJ 3640: JC的小苹果 [概率DP 高斯消元 矩阵求逆]

    3640: JC的小苹果 题意:求1到n点权和\(\le k\)的概率 sengxian orz的题解好详细啊 容易想到\(f[i][j]\)表示走到i点权为j的概率 按点权分层,可以DP 但是对于\ ...

  9. 高斯消元 & 线性基【学习笔记】

    高斯消元 & 线性基 本来说不写了,但还是写点吧 [update 2017-02-18]现在发现真的有好多需要思考的地方,网上很多代码感觉都是错误的,虽然题目通过了 [update 2017- ...

随机推荐

  1. 【Java基础】多线程

    多线程 基本概念 程序(program)是为完成特定任务.用某种语言编写的一组指令的集合.即指一段静态的代码,静态对象. 进程(process)是程序的一次执行过程,或是正在运行的一个程序.是一个动态 ...

  2. C#中的异步和多线程

    许多开发人员对异步代码和多线程以及它们的工作原理和使用方法都有错误的认识.在这里,你将了解这两个概念之间的区别,并使用c#实现它们. 我:"服务员,这是我第一次来这家餐厅.通常需要4个小时才 ...

  3. NAS基础知识

    一.什么是NAS 1.NAS的定义 NAS(Network Attached Storage:网络附属存储)按字面简单说就是连接在网络上,具备资料存储功能的装置,因此也称为"网络存储器&qu ...

  4. CAN总线采样点测试

    采样点是什么? 采样点是接受节点判断信号逻辑的位置,CAN通讯属于异步通讯.需要通过不断的重新同步才能保证收发节点的采样准确. 若采样点太靠前,则因为线缆原因,DUT外发报文尚未稳定,容易发生采样错误 ...

  5. 【Linux】fio测试读写速度

    需要安装fio yum install fio -y 有很多依赖包     FIO用法: 随机读:(可直接用,向磁盘写一个2G文件,10线程,随机读1分钟,给出结果) fio -filename=/h ...

  6. Loadrunner参数化数据配置与更新方式

    之前遇到过一种情况,对脚本进行并发测试时,脚本没有报错,但是有丢失的事物,与开发配合检查确定不是代码的问题,然后检查脚本,更换参数化数据配置与更新方式,问题解决.现在对参数化数据配置和更新方式进行总结 ...

  7. java.net.NoRouteToHostException: 没有到主机的路由

    今天在配置Jenkins 的云服务器的时候提示:java.net.NoRouteToHostException: 没有到主机的路由,网上查到的没有主机路由问题提到的大多是防火墙问题. 查看防火墙状态: ...

  8. Python+Selenium+Unittest实现PO模式web自动化框架(8)

    1.main.py模块的功能 最后就是要有一个项目入口,并且是需要加载测试用例集. # --^_^-- coding:utf-8 --^_^-- # @Remark:运行入口 "" ...

  9. CentOS7.9静默安装Oracle19C软件

    CentOS7.9静默安装Oracle19C软件 Oracle发布了支持的版本.可以看到了Oracle11gR2和Oracle12C.一直到2022年就不支持patch和服务.(感慨Oracle 11 ...

  10. python RecursionError: maximum recursion depth exceeded while calling

    import copyimport sys # 导入sys模块sys.setrecursionlimit(8192) # 将默认的递归深度修改为r = sys.getrecursionlimit()_ ...