xor方程组消元 UVA 11542 Square
生活随笔
收集整理的這篇文章主要介紹了
xor方程组消元 UVA 11542 Square
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
?
題目傳送門
題意:給n個數,選擇一些數字乘積為平方數的選擇方案數。訓練指南題目。
分析:每一個數字分解質因數。比如4, 6, 10, 15,,?,?,?, 令,表示選擇第i個數字,那么,如果p是平方數,那么每個質因數上的指數為偶數,x1系數為2已經是偶數不考慮。可以轉換為異或為0判斷偶數,即奇數置為1,偶數置為0,然后n個數字m個質因數的增廣矩陣消元看有幾個自由變量(取0或1無所謂),答案是2^r - 1(全部都不取方案不算)
#include <bits/stdc++.h>const int N = 500 + 5; bool vis[N]; int prime[N]; int A[N][105];void sieve(int n) {int m = sqrt (n + 0.5);for (int i=2; i<=m; ++i) {if (!vis[i]) {for (int j=i*2; j<=n; j+=i) {vis[j] = true;}}} }int gen_prime(int n) {memset (vis, false, sizeof (vis));sieve (n);int c = 0;for (int i=2; i<=n; ++i) {if (!vis[i]) {prime[c++] = i;}}return c; }int rank(int m, int n) {int i = 0, j = 0;while (i < m && j < n) {int r = i;for (int k=i; k<m; ++k) {if (A[k][j]) {r = k;break;}}if (A[r][j]) {if (r != i) {//!for (int k=0; k<=n; ++k) {std::swap (A[r][k], A[i][k]);}}for (int k=i+1; k<m; ++k) {if (A[k][j]) {for (int c=i; c<=n; ++c) {A[k][c] ^= A[i][c];}}}++i;}++j;}return i; }//Running_Time int main() {int T; scanf ("%d", &T);int m = gen_prime (500);while (T--) {int n; scanf ("%d", &n);memset (A, 0, sizeof (A));int maxp = 100;for (int i=0; i<n; ++i) {long long x; scanf ("%lld", &x);for (int j=0; j<m; ++j) {while (x % prime[j] == 0) {x /= prime[j];A[j][i] ^= 1;maxp = std::max (maxp, j);}}}int r = rank (maxp+1, n);std::cout << ((1LL << (n - r)) - 1) << '\n';}return 0; }
轉載于:https://www.cnblogs.com/Running-Time/p/5365681.html
總結
以上是生活随笔為你收集整理的xor方程组消元 UVA 11542 Square的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 梦到花生豆什么意思
- 下一篇: Lua语法基础(1)---简介、基本数据