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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

bzoj 3811 玛里苟斯 - 线性基

發布時間:2023/12/14 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 bzoj 3811 玛里苟斯 - 线性基 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目傳送門

  傳送門I

  傳送門II

題目大意

  給定集合$S$,問集合$S$的任意選一個子集的異或和的$k$次冪期望。

  保證答案在$2^{63}$內。

  注意到答案在$2^{63}$內,所以,當$k \geqslant 3$的時候,$a_{i} \leqslant 2^{21}$,這意味著本質不同的異或結果至多$2^{21}$個。

  于是可以做線性基,然后暴力枚舉子集計算異或和$k$次冪。

  注意答案在$2^{63}$內,但是中間結果會溢出。所以用兩個unsigned long long來壓成__int128。

  恰好除數為$2^{\left | \mathfrak{B} \right |}$。可以保留$\left \lfloor \frac{ans}{2^{\left | \mathfrak{B} \right |}} \right \rfloor$,以及除以$2^{\left | \mathfrak{B} \right |}$的余數。

  現在考慮$k < 3$的情況。

  • 如果$k = 1$,分別考慮每一位,如果這一位存在1個數為1,那么異或后這一位為1的概率為$\frac{1}{2}$,因為選了多少個這一位為0個數不會影響,有影響的只是選了這一位為$1$的數的奇偶性。記得之前某篇博客里證明過,非空集合的奇子集的數量等于偶子集的數量。但是如果不存在這一位為1的數,那么結果為$0$。
  • 如果$k = 2$。那么對于一個異或和$x = b_{p}b_{p - 1}\cdots b_{0}$,它的貢獻為$\sum_{i = 0}^{p}\sum_{j = 0}^{p} b_{i} \cdot b_{j} \cdot 2^{i + j}$。
    然后考慮枚舉任意兩個二進制位,考慮它們對答案的貢獻。
    接著需要做的事是,考慮選取一個子集,它的異或和在第$i$位和第$j$位上的值同時為1的概率(否則沒有貢獻)。
    如果第$i$位和第$j$位上,如果其中一個不存在一個數在這一位上為1,那么概率為0。
    如果第$i$位和第$j$位上,不滿足上面的條件,但所有數這兩位上的值都相等,那么概率為$\frac{1}{2}$。
    如果以上兩種情況都不滿足。考慮對于每一個數將這兩位上的值看成一個二元組$(b_{i}, b_{j})$,當且僅當它為$(1, 1)$時,才對答案有貢獻。
    1.考慮選出的$(1, 1)$的個數為奇數,它的概率為$\frac{1}{2}$,那么選出的$(0, 0)$的數量不限,$(0, 1)$的個數為奇數,$(1, 0)$的個數為奇數,它們的概率分別為$\frac{1}{2}$,這一部分總的概率是$1\times \left(\frac{1}{2} \right)^{3} = \frac{1}{8}$。
    2.考慮選出的$(1, 1)$的個數為偶數,這一部分的概率也是$\frac{1}{8}$。
    所以這樣的概率總的為$\frac{1}{8}\times 2 = \frac{1}{4}$。

  由于異或的最后一位為1的概率為$\frac{1}{2}$或者$0$,因此,結果的小數位要么是0,要么是.5。

  然后這道題要用unsigned long long存答案,不然會WA。

Code

1 /** 2 * bzoj 3 * Problem#3811 4 * Accepted 5 * Time: 1256ms 6 * Memory: 2076k 7 */ 8 #include <bits/stdc++.h> 9 #ifdef WIN32 10 #define Auto "%I64u" 11 #else 12 #define Auto "%llu" 13 #endif 14 using namespace std; 15 typedef bool boolean; 16 17 #define ll unsigned long long 18 19 int n, k; 20 ll *ar; 21 22 inline void init() { 23 scanf("%d%d", &n, &k); 24 ar = new ll[(n + 1)]; 25 for (int i = 1; i <= n; i++) 26 scanf(Auto, ar + i); 27 } 28 29 namespace small { 30 31 ll res = 0, ans = 0; 32 inline void solve() { 33 if (k == 1) { 34 for (int i = 1; i <= n; i++) 35 res |= ar[i]; 36 printf(Auto, res >> 1); 37 (res & 1) ? (puts(".5")) : (0); 38 } else { 39 for (int i = 0; i < 32; i++) 40 for (int j = 0; j < 32; j++) { 41 boolean aflag = false; 42 for (int k = 1; k <= n && !aflag; k++) 43 if (ar[k] & (1ll << i)) 44 aflag = true; 45 if (!aflag) continue; 46 aflag = false; 47 for (int k = 1; k <= n && !aflag; k++) 48 if (ar[k] & (1ll << j)) 49 aflag = true; 50 if (!aflag) continue; 51 aflag = false; 52 for (int k = 1; k <= n && !aflag; k++) 53 if (((ar[k] >> i) & 1) != ((ar[k] >> j) & 1)) aflag = true; 54 int p = i + j - aflag - 1; 55 if (p < 0) 56 res++; 57 else 58 ans += 1ll << p; 59 } 60 ans += (res >> 1), res &= 1; 61 printf(Auto, ans); 62 (res) ? puts(".5") : 0; 63 } 64 } 65 66 } 67 68 namespace big { 69 const int maxbase = 23; 70 ll br[maxbase]; 71 vector<ll> v; 72 ll ans = 0, res = 0; 73 74 inline void solve() { 75 for (int i = 1; i <= n; i++) 76 for (int j = maxbase - 1; ~j && ar[i]; j--) { 77 if ((ar[i] >> j) & 1) { 78 if (br[j]) 79 ar[i] ^= br[j]; 80 else 81 br[j] = ar[i], ar[i] = 0; 82 } 83 } 84 for (int i = 0; i < maxbase; i++) 85 if (br[i]) 86 v.push_back(br[i]); 87 int s = (signed)v.size(); 88 ll mask = (1ull << s) - 1; 89 for (int i = 0; i <= mask; i++) { 90 ll xs = 0; 91 for (int j = 0; j < s; j++) 92 if (i & (1 << j)) 93 xs ^= v[j]; 94 ll a = 0, b = 1; 95 for (int i = 0; i < k; i++) { 96 a = a * xs, b = b * xs; 97 a += (b >> s), b &= mask; 98 } 99 100 ans += a, res += b; 101 ans += (res >> s), res &= mask; 102 } 103 printf(Auto, ans); 104 puts((res) ? (".5") : ("")); 105 } 106 } 107 108 int main() { 109 init(); 110 if (k < 3) 111 small::solve(); 112 else 113 big::solve(); 114 return 0; 115 }

轉載于:https://www.cnblogs.com/yyf0309/p/8698413.html

總結

以上是生活随笔為你收集整理的bzoj 3811 玛里苟斯 - 线性基的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 天天做天天爽 | 91在线精品秘密一区二区 | 极品美妇后花庭翘臀娇吟小说 | 久久一 | 一级a毛片免费观看久久精品 | 香蕉国产999| 成人日皮视频 | 国产亚洲女人久久久久毛片 | 天天干天天日夜夜操 | 任我爽在线 | 国内精品嫩模av私拍在线观看 | 天堂激情网 | sm在线看 | 网址av| 亚洲av无码专区在线 | 插我舔内射18免费视频 | 69堂精品| 亚洲第一福利视频 | 伊人久久久 | 日本a级在线 | 91在线网址| 黄色a网站| 欧美有码在线观看 | 秋葵视频在线 | 一区二区三区麻豆 | 亚洲精品免费视频 | 欧美日韩高清一区二区三区 | 激情文学综合网 | 国产第8页 | 高清成人| 天天摸天天做天天爽 | 亚洲综合免费观看高清完整版在线 | 国产精品美女久久久免费 | 亚洲色图第一区 | 国产美女精品视频国产 | 亚洲三级影视 | 精品人妻一区二区三区蜜桃 | 尤物网站在线播放 | 久久久精品在线 | 国产欧美一区二区三区另类精品 | 自拍偷拍激情 | 国产男同gay网站 | 极品人妻一区二区 | 91蜜桃网| 免费在线黄色网址 | 亚洲精品影院 | 国产a大片 | 日本一区视频在线播放 | 三度诱惑免费版电影在线观看 | 少妇人妻偷人精品无码视频新浪 | 欧美午夜精品久久久久久浪潮 | 黄色录像一级大片 | 在线亚洲免费 | 少妇毛片视频 | 成人在线一区二区三区 | 97香蕉超级碰碰久久免费软件 | 青青草原国产 | 男女洗澡互摸私密部位视频 | 欧美性猛片aaaaaaa做受 | 日韩精品一区在线观看 | 国产精品乱码一区二区 | 欧美成人片在线观看 | 日韩精品网 | 天天爱天天做天天爽 | 操极品少妇 | 成人免费在线网址 | 在线欧美日韩 | 空姐吹箫视频大全 | 国产一级大片在线观看 | 久久久一区二区三区 | 日韩欧美视频免费观看 | 国产精品国产三级国产传播 | 亚洲一区影视 | 亚洲一区二区三区久久 | 黄色片网站大全 | 国产一区综合 | 免费高清毛片 | 丝袜性爱视频 | 亚洲国产精品无码久久久久高潮 | 青青久久av北条麻妃黑人 | 毛片毛多水多 | 三上悠亚中文字幕在线播放 | 91爱爱爱爱 | 少妇高潮一区二区三区99小说 | 亚洲品质自拍视频 | 亚洲欧美网站 | 一卡二卡三卡 | 不卡免费av | 国产精品永久免费 | 激情亚洲天堂 | 男人操女人的视频 | 91精品国产99久久久久久红楼 | 久久综合中文 | 色污网站| av网址在线看 | 伊人久久大香线蕉av一区 | 国产夫妻av| 人妻无码一区二区三区免费 | 黄网在线观看视频 |