博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UVA11542 Square(高斯消元 异或方程组)
阅读量:6257 次
发布时间:2019-06-22

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

 

建立方程组消元,结果为2 ^(自由变元的个数) - 1

采用高斯消元求矩阵的秩

 方法一:

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;typedef long long LL;const int N = 108, INF = 0x3F3F3F3F;const double eps = 1e-8;int a[N][N];template
int gauss_jordan(T A[N][N], int n, int m){ int i, c; for(i = 0, c = 0; i < n && c < m; i++, c++){ int r = i; for(int j = i + 1; j < n; j++){ if(A[j][c]){ r = j; break; } } if(A[r][c] == 0){ i--; continue; } if(r != i){ for(int j = 0; j <= m; j++){ swap(A[r][j], A[i][j]); } } for(int k = 0; k < n; k++){ if(k != i && A[k][c]){ for(int j = m; j >= c; j--){ A[k][j] ^= A[i][j]; } } } } return i;}const int MAXN = 508;int prime[MAXN];bool vis[MAXN];int getPrime(int n){//求1~n的素数 int tot=0; memset(vis,0,sizeof(vis)); for(int i=2;i<=n;i++){ if(!vis[i]){ prime[tot++]=i; } for(int j=0;j
<=n;j++){ vis[i*prime[j]]=true; if(i%prime[j]==0){//让每个合数仅被其最小的质数筛去 break; } } } return tot;}int main(){ int cnt = getPrime(500); int t; cin>>t; while(t--){ memset(a, 0, sizeof(a)); int n; cin>>n; for(int j = 0; j < n; j++){ LL x; cin>>x; for(int i = 0; i < cnt && prime[i]<= x; i++){ while(x % prime[i] == 0){ a[i][j] ^= 1; x /= prime[i]; } } } LL ans = n - gauss_jordan(a, cnt, n); //cout<
<<" ans\n"; cout<<((1ll << ans) - 1)<<'\n'; } return 0;}

 

方法2:

消元后非0向量的行数即为矩阵的秩,但开始出现问题一直WA,后来在消元变成上三角矩阵后,从最后一行起,找出第一个非0元素,向上消元。

应该有更巧妙的写法避免这个问题。

 

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;typedef long long LL;const int N = 108, INF = 0x3F3F3F3F;const double eps = 1e-8;int a[N][N];template
void gauss_jordan(T A[N][N], int n, int m){ for(int i = 0; i < n; i++){ int r = i; for(int j = i + 1; j < n; j++){ if(A[j][i]){ r = j; break; } } if(A[r][i] == 0){ continue; } if(r != i){ for(int j = 0; j <= m; j++){ swap(A[r][j], A[i][j]); } } for(int k = i + 1; k < n; k++){ if(k != i && A[k][i]){ for(int j = m; j >= i; j--){ A[k][j] ^= A[i][j]; } } } } for(int i = n - 1; i > 0; i--){ for(int j = 0; j < m; j++){ if(A[i][j]){ for(int k = i - 1; k >= 0; k--){ if(A[k][j]){ for(int l = j; l <= m; l++){ A[k][l] ^= A[i][l]; } } } break; } } }}const int MAXN = 508;int prime[MAXN];bool vis[MAXN];int getPrime(int n){//求1~n的素数 int tot=0; memset(vis,0,sizeof(vis)); for(int i=2;i<=n;i++){ if(!vis[i]){ prime[tot++]=i; } for(int j=0;j
<=n;j++){ vis[i*prime[j]]=true; if(i%prime[j]==0){//让每个合数仅被其最小的质数筛去 break; } } } return tot;}int main(){ int cnt = getPrime(500); int t; cin>>t; while(t--){ memset(a, 0, sizeof(a)); int n; int row = 0; cin>>n; for(int j = 0; j < n; j++){ LL x; cin>>x; for(int i = 0; i < cnt && prime[i]<= x; i++){ while(x % prime[i] == 0){ row = max(row, i); a[i][j] ^= 1; x /= prime[i]; } } } row++; gauss_jordan(a, row, n); int rk = 0; for(int i = 0; i < row; i++){ for(int j = 0; j < n; j++){ if(a[i][j]){ rk++; break; } } } n -= rk; cout<<((1ll << n) - 1)<<'\n'; } return 0;}

  

转载于:https://www.cnblogs.com/IMGavin/p/5930604.html

你可能感兴趣的文章
顺序图【6】--☆☆
查看>>
Docker Swarm 让你事半功倍
查看>>
[转]IC行业的牛人
查看>>
javaScript事件(四)event的公共成员(属性和方法)
查看>>
linux系统常用命令
查看>>
在 Word 中的受支持的区域设置标识符的列表
查看>>
Caffe + Ubuntu 14.04 64bit + CUDA 6.5 配置说明2
查看>>
An easy to use android color picker library
查看>>
Oracle SID爆破工具SidGuess
查看>>
批处理常用命令总结2
查看>>
解读ASP.NET 5 & MVC6系列(9):日志框架
查看>>
Android -- 自定义View小Demo,绘制钟表时间(一)
查看>>
信息检索Reading List
查看>>
JavaWeb_JavaEE_命名规则
查看>>
申小雨命案审理延期至3月5日 警方将翻译嫌犯口供
查看>>
自动精简配置&重复数据删除核心技术点及其经济效应探究
查看>>
cncert网络安全周报35期 境内被植入后门的政府网站112个 环比上涨24.4%
查看>>
物联网到底是不是泡沫,且看英特尔交出的答案
查看>>
IPv6太落后了:中国加速服务器援建
查看>>
安防大数据应用国家工程实验室在乌鲁木齐成立
查看>>