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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

【AGC035C】Skolem XOR Tree【异或】【构造】

發布時間:2023/12/3 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【AGC035C】Skolem XOR Tree【异或】【构造】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

傳送門

題意:給定nnn,構造或判斷無法構造一個2n2n2n個結點的樹,其中結點iiii+ni+ni+n的權值為iii,且所有iiii+ni+ni+n路徑權值異或和等于iii

注意到 2i⊕2i+1=12i\oplus2i+1=12i2i+1=1,然后可以腦補出

然而111沒處理 發現1⊕2⊕3=01\oplus2\oplus3=0123=0,可以用樣例中的方法排出1→2→3→n+1→n+2→n+31\to2\to3\to n+1\to n+2\to n+3123n+1n+2n+3,后面按上面的方法構造

如果nnn為偶數最后會剩下一個nnn2n2n2n

考慮找到x,yx,yx,y使x⊕y⊕1=nx\oplus y \oplus 1=nxy1=n,然后連接(n,x)(2n,y)(n,x)(2n,y)(n,x)(2n,y)

但是333沒有接在111上,所以不能選

所以x,yx,yx,y需要滿足1<x<n1<x<n1<x<nx≠3x\neq3x?=3,yyy一樣

下面討論什么條件下可以找到這樣的x,yx,yx,y:(注意nnn是偶數)

nnn222的正整數次冪,顯然是無解的

如果n=2k+2(k>2)n=2^k+2(k>2)n=2k+2(k>2),即x⊕y=2k+3x\oplus y=2^k+3xy=2k+3,令x=2k+1,y=2x=2^k+1,y=2x=2k+1,y=2

否則直接把nnn的二進制最高位拆出來

即只有n=2kn=2^kn=2k是無解的

#include <iostream> #include <cstdio> #include <cstring> #include <cctype> using namespace std; int main() {int n;scanf("%d",&n);if (!(n&(n-1))) return puts("No"),0;puts("Yes");printf("1 2\n2 3\n3 %d\n%d %d\n%d %d\n",n+1,n+1,n+2,n+2,n+3);for (int i=4;i<n;i+=2) printf("1 %d\n%d %d\n1 %d\n%d %d\n",i,i,i+1+n,i+1,i+1,i+n);if (!(n&1)){for (int i=2;i<=n;i++){int j=i^n^1;if (i!=3&&j!=3&&j<=n){printf("%d %d\n%d %d\n",i,n,j,2*n);break;}}}return 0; }

總結

以上是生活随笔為你收集整理的【AGC035C】Skolem XOR Tree【异或】【构造】的全部內容,希望文章能夠幫你解決所遇到的問題。

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