【AGC035C】Skolem XOR Tree【异或】【构造】
傳送門
題意:給定nnn,構(gòu)造或判斷無法構(gòu)造一個2n2n2n個結(jié)點的樹,其中結(jié)點iii和i+ni+ni+n的權(quán)值為iii,且所有iii和i+ni+ni+n路徑權(quán)值異或和等于iii。
注意到 2i⊕2i+1=12i\oplus2i+1=12i⊕2i+1=1,然后可以腦補出
然而111沒處理 發(fā)現(xiàn)1⊕2⊕3=01\oplus2\oplus3=01⊕2⊕3=0,可以用樣例中的方法排出1→2→3→n+1→n+2→n+31\to2\to3\to n+1\to n+2\to n+31→2→3→n+1→n+2→n+3,后面按上面的方法構(gòu)造
如果nnn為偶數(shù)最后會剩下一個nnn和2n2n2n
考慮找到x,yx,yx,y使x⊕y⊕1=nx\oplus y \oplus 1=nx⊕y⊕1=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<n且x≠3x\neq3x?=3,yyy一樣
下面討論什么條件下可以找到這樣的x,yx,yx,y:(注意nnn是偶數(shù))
當nnn是222的正整數(shù)次冪,顯然是無解的
如果n=2k+2(k>2)n=2^k+2(k>2)n=2k+2(k>2),即x⊕y=2k+3x\oplus y=2^k+3x⊕y=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; }總結(jié)
以上是生活随笔為你收集整理的【AGC035C】Skolem XOR Tree【异或】【构造】的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 假阳性是什么意思
- 下一篇: 【Hitachi2020C】ThREE【