HDU 4149 Magic Potion

2015-11-21 01:58:09 · 作者: · 浏览: 10

题意:

a[i] ^ x = f[i] ( i = 1...8 ) 和 ( a[1] + a[2] + ... + a[8] ) ^ x = f[9] 现在f为已知 求x


思路:

从低位到高位确定x值 做法见注释


代码:

#include
  
   
#include
   
     #include
    
      using namespace std; int f[20],t,ans; int main() { int i,k,j; scanf("%d",&t); while(t--) { ans=0; f[0]=0; //用来存a[1]^a[2]^...^a[8] for(i=1;i<=8;i++) { scanf("%d",&f[i]); f[0]^=f[i]; } scanf("%d",&f[9]); for(i=k=0;i<32;i++) { //printf("%d %d %d\n",i,ans,k); if(f[0]&(1<