题目链接

将题目转化为矩乘问题

构建一个 \(n \times n\) 的开关信息矩阵,其中第 \(i\) 第 \(j\) 行的元素为 \(0 / 1\) 代表在改变开关 \(i\) 的情况下开关 \(j\) 是否会改变

将该开关信息矩阵乘上一个 \(n\times 1\) 的答案矩阵,其中第 \(i\) 行的元素为 \(0/1\) 代表是否拉第 \(i\) 个开关

得到的是一个 \(n\times 1\) 的矩阵,将其与开关的初始状态矩阵 逐位相异或(注意,不是矩乘) 若得到开关的结果状态矩阵,则答案加一

利用异或的性质 a^b=b^a ,将结果矩阵逐位异或上初始矩阵,我们就得到了矩乘的标准形式 \(Ax=b\)

最后的答案即为 \(x\) 的 \(2\) 的自由元个数次方 (因为每个自由元只可取 \(0/1\)),也即 \(2\) 的 \(n-rank(A)\) 次方

下面是代码:

#include <iostream>
#include <cstring> using namespace std; const int MAX_N = 50; int mat[MAX_N][MAX_N]; int Gauss(int n) {
int rank = 0;
for (int col = 0; col < n; ++col) { // 逐列找 pivot
int pivotRow = -1;
for (int row = rank; row < n; ++row) {
if (mat[row][col]) { // 找到了,记录 pivot 所在行的位置
pivotRow = row;
break;
}
}
if (pivotRow == -1) continue; // 没找到,自由元++
for (int i = 0; i <= n; ++i)
swap(mat[pivotRow][i], mat[rank][i]); // 将 pivot 所在行的位置交换到第 rank 行(行数从 0 开始) 以形成下三角矩阵
for (int i = rank + 1; i < n; ++i) {
if (mat[i][col]) {
for (int j = col; j <= n; ++j) mat[i][j] ^= mat[rank][j]; // 异或消元
}
}
++rank; // 矩阵的阶++
}
for (int row = rank; row < n; ++row)
if (mat[row][n]) return -1; // 高消后此时 rank+1 ~ n 行左边全为 0,若最右元素仍不为 0 则出现了 0=n,方程无解
return rank; // 返回矩阵 A 的阶
} int main() { int k;
cin >> k;
while (k--) {
int n;
cin >> n;
for (int i = 0; i < n; ++i)
mat[i][i] = 1;
for (int i = 0; i < n; ++i) {
int x;
cin >> x;
mat[i][n] ^= x;
}
for (int i = 0; i < n; ++i) {
int x;
cin >> x;
mat[i][n] ^= x; // 构建 b 结果状态矩阵(向量)
}
int x, y;
while (cin >> x >> y) {
if (!x && !y) break;
mat[y - 1][x - 1] = 1; // 构建 A 矩阵
}
int ans = Gauss(n);
if (~ans) {
cout << (1 << (n - ans)) << endl; // n-rank(A) 即自由元个数,每个自由元都有 0/1 两种可能取值
} else {
cout << "Oh,it's impossible~!!" << endl;
}
memset(mat, 0, sizeof(mat));
} return 0;
}

POJ 1830 开关问题 异或高斯消元的更多相关文章

  1. poj1830开关问题——异或高斯消元

    题目:http://poj.org/problem?id=1830 根据题意,构造出n元方程组: a(1,1)x1 ^ a(1,2)x2 ^ a(1,3)x3 ... a(1,n)xn = st1 ^ ...

  2. POJ 1222【异或高斯消元|二进制状态枚举】

    题目链接:[http://poj.org/problem?id=1222] 题意:Light Out,给出一个5 * 6的0,1矩阵,0表示灯熄灭,反之为灯亮.输出一种方案,使得所有的等都被熄灭. 题 ...

  3. POJ 1222 EXTENDED LIGHTS OUT(高斯消元解异或方程组)

    EXTENDED LIGHTS OUT Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 10835   Accepted: 6 ...

  4. POJ 1222 EXTENDED LIGHTS OUT(高斯消元解XOR方程组)

    http://poj.org/problem?id=1222 题意:现在有5*6的开关,1表示亮,0表示灭,按下一个开关后,它上下左右的灯泡会改变亮灭状态,要怎么按使得灯泡全部处于灭状态,输出方案,1 ...

  5. POJ 1222 EXTENDED LIGHTS OUT(高斯消元)

    [题目链接] http://poj.org/problem?id=1222 [题目大意] 给出一个6*5的矩阵,由0和1构成,要求将其全部变成0,每个格子和周围的四个格子联动,就是说,如果一个格子变了 ...

  6. POJ 3185 The Water Bowls(高斯消元-枚举变元个数)

    题目链接:http://poj.org/problem?id=3185 题意:20盏灯排成一排.操作第i盏灯的时候,i-1和i+1盏灯的状态均会改变.给定初始状态,问最少操作多少盏灯使得所有灯的状态最 ...

  7. SGU 260.Puzzle (异或高斯消元)

    题意: 有n(<200)个格子,只有黑白两种颜色.可以通过操作一个格子改变它和其它一些格子的颜色.给出改变的关系和n个格子的初始颜色,输出一种操作方案使所有格子的颜色相同. Solution: ...

  8. Luogu3164 CQOI2014 和谐矩阵 异或高斯消元

    传送门 题意:给出$N,M$,试构造一个$N \times M$的非全$0$矩阵,其中所有格子都满足:它和它上下左右四个格子的权值之和为偶数.$N , M \leq 40$ 可以依据题目中的条件列出有 ...

  9. POJ 1222 EXTENDED LIGHTS OUT(高斯消元)题解

    题意:5*6的格子,你翻一个地方,那么这个地方和上下左右的格子都会翻面,要求把所有为1的格子翻成0,输出一个5*6的矩阵,把要翻的赋值1,不翻的0,每个格子只翻1次 思路:poj 1222 高斯消元详 ...

  10. POJ 1681 Painter's Problem(高斯消元+枚举自由变元)

    http://poj.org/problem?id=1681 题意:有一块只有黄白颜色的n*n的板子,每次刷一块格子时,上下左右都会改变颜色,求最少刷几次可以使得全部变成黄色. 思路: 这道题目也就是 ...

随机推荐

  1. TCP和UDP协议之间的区别与原理

    一.TCP和UDP协议之间的区别 TCP是基于连接的,而UDP是基于非连接的. TCP传输数据稳定可靠,适用于对网络通讯质量要求较高的场景,需要准确无误的传输给对方,比如,传输文件,发送邮件,浏览网页 ...

  2. Java8 Date Time API 简介

    1.Java8 Date Time API 简介 1.1.新旧 Date Time API 对比 包位置对比 1.Java8之前的日期.时间分布在java.util和java.sql的包中,此外用于格 ...

  3. 20203412马畅若 实验二《Python程序设计》实验报告

    20203412马畅若    实验二<Python程序设计>实验报告 课程:<Python程序设计>班级: 2034姓名:马畅若学号:20203412实验教师:王志强实验日期: ...

  4. docker-compose任务编排

    一.docker-compose介绍 使用一个Dockerfile模板文件可以定义一个单独的应用容器,如果需要定义多个容器就需要服务编排.下面介绍Docker官方产品,Docker Compose. ...

  5. gopher必读文章

    Getting Started with Go Programminghttps://www.programiz.com/golang/getting-startedHow to Write Go C ...

  6. H5网页CAD中webpack使用详细说明

    前言 webpack是用于现代 JavaScript 应用程序的静态模块打包工具,用以构建一个前端工程化项目,如vue-cli create-react-app等脚手架工具都是基于webpack的构建 ...

  7. noi 45 金币

    noi 45 金币 1.描述 国王将金币作为工资,发放给忠诚的骑士.第一天,骑士收到一枚金币:之后两天(第二天和第三天)里,每天收到两枚金币:之后三天(第四.五.六天)里,每天收到三枚金币:之后四天( ...

  8. 攻防世界-file_include(绕过base64)

    有简单过滤防护的文件包含  一.源码分析 易知$filename处可能会存在文件包含漏洞.但注意到include了一个./check.php文件,猜测可能有过滤.先不管,于是直接使用普通payload ...

  9. 为什么用postman

    1,  保存测试的记录, 就是确保访问的地址,数据什么的,得到的结果是有效的2,  假设开始一个访问, 然后方便在本地debug, 因为有些访问是不能通过本地的浏览器来访问的, 比如前后端分离的情况, ...

  10. STM32F0使用LL库实现UART接收

    初始化: 1 void MX_USART1_UART_Init(void) 2 { 3 4 /* USER CODE BEGIN USART1_Init 0 */ 5 6 /* USER CODE E ...