高斯消元解异或线性方程组

cpp 复制代码
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'

using namespace std;

typedef pair<int, int> PII;
typedef long long ll;
typedef long double ld;

const int N = 110;

int n;
int a[N][N];

int gauss()
{
	int r, c;
	for(r = 0, c = 0; c < n; c ++)
	{
		int t = r;
		for(int i = r; i < n; i ++)
		{
			if(a[i][c])
			{
				t = i;
				break;
			}
		}
		
		if(!a[t][c])continue;
		
		for(int j = c; j <= n; j ++)swap(a[t][j], a[r][j]);
		
		for(int i = r + 1; i < n; i ++)
			if(a[i][c])
				for(int j = n; j >= c; j --)
					a[i][j] ^= a[r][j];
					
		r ++;
	}
	
	if(r < n)
	{
		for(int i = r; i < n; i ++)
			if(a[i][n])
				return 2;
		return 1;
	}
	
	for(int i = n - 1; i >= 0; i --)
		for(int j = i + 1; j < n; j ++)
			a[i][n] ^= a[i][j] & a[j][n];
	
	return 0;
}

int main()
{
	scanf("%d", &n);
	for(int i = 0; i < n; i ++)
		for(int j = 0; j <= n; j ++)
			scanf("%d", &a[i][j]);
			
	int t = gauss();
	
	if(t == 0)
	{
		for(int i = 0; i < n; i ++)
		{
			printf("%d\n", a[i][n]);
		}
	}
	else if(t == 1)printf("Multiple sets of solutions\n");
	else printf("No solution\n");
	
	return 0;
}
相关推荐
用户9704438781163 分钟前
按图搜索1688商品(拍立淘)API 返回值说明
javascript·后端·算法
末央&5 分钟前
【C++】vector的底层封装和实现
android·c++
勤劳的进取家26 分钟前
贪心算法的使用条件
数据结构·python·算法·贪心算法·排序算法·动态规划
十七算法实验室1 小时前
Matlab实现鼠群优化算法优化随机森林算法模型 (ROS-RF)(附源码)
开发语言·算法·决策树·随机森林·机器学习·支持向量机·matlab
烁3471 小时前
每日一题(小白)字符串娱乐篇16
java·开发语言·算法·娱乐·暴力
butiehua02021 小时前
Go语言常用算法实现
数据结构·算法·golang·排序算法
Tadecanlan1 小时前
[C++面试] C++中各类括号的差异:[]、{}、<>、()
开发语言·c++·面试
luckycoding1 小时前
1631. 最小体力消耗路径
数据结构·算法·leetcode
.YY001.1 小时前
数据结构第一轮复习--第七章查找(包含课程代码)
数据结构·算法
_GR1 小时前
2023年蓝桥杯第十四届C&C++大学B组真题及代码
c语言·c++·蓝桥杯