日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

xor方程组消元 UVA 11542 Square

發布時間:2023/11/29 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。