Contest2037 - CSU Monthly 2013 Oct (problem F 1323: ZZY and his little friends)
你为何这么叼!
1323: ZZY and his little friends
Time Limit: 5 Sec Memory Limit: 256 MBSubmit: 241 Solved: 104
[Submit][Status][Web Board]
Description
zzy养了一只小怪兽和N只凹凸曼,单挑的话每只凹凸曼都不是小怪兽的对手,所以必须由两只凹凸曼合作来和小怪兽战斗。凹凸曼A和凹凸曼B合作的战斗力为他们战斗力的异或值。现在由zzy从N只凹凸曼中选出两只来和小怪兽战斗。请问zzy能否选出两只凹凸曼使他们能够战胜小怪兽(他们的战斗力比小怪兽大)。
Input
输入有多个例子,直到文件结束。 每个例子的第一行含两个数N和M,表示有N(2<=N<=100000)只凹凸曼,小怪兽的战斗力为M(0<M<=1000000000)。接着有一行N个数,每个数Ai(0<Ai<M)表示每只凹凸曼的战斗力。
Output
对于每个例子输出一行,如果能选出两只凹凸曼使他们战胜小怪兽输出"YES", 否则输出"NO"(不含引号)
Sample Input
2 5
1 1
2 6
5 2
Sample Output
NO
YES
HINT
CSU_CX
Source
再次感谢学长大大指导建树!,尼玛10W居然暴力能过!
1 #include <cstdio> 2 #include <vector> 3 #include <cstring> 4 #include <algorithm> 5 using namespace std; 6 #define maxn 100005 7 #define INF 0x7fffffff 8 int n,m,s,ma; 9 int x[32]; 10 int a[32]; 11 struct Node{ 12 Node *left; 13 Node *right; 14 Node(){ clear(); } 15 void clear(){ 16 left=right=0; 17 } 18 }T; 19 void fun(int t){ 20 memset(a,0,sizeof a); 21 int b[32]={0}; 22 int i=0; 23 while(t){ 24 b[i++]=t%2; 25 t/=2; 26 } 27 int k=0; 28 for(int j=30;k<i;j--,k++) a[j]=b[k]; 29 } 30 void Add(){ 31 Node *P=&T; 32 for(int i=0;i<31;i++){ 33 if(a[i]==0){ 34 if(P->left==NULL) 35 P->left=new Node; 36 P=P->left; 37 } 38 else{ 39 if(P->right==NULL) 40 P->right=new Node; 41 P=P->right; 42 } 43 } 44 } 45 int dfs(){ 46 Node *P=&T; 47 memset(x,0,sizeof x); 48 for(int i=0;i<31;i++){ 49 if(a[i]==0){ 50 if(P->right!=NULL) 51 x[i]=1,P=P->right; 52 else if(P->left!=NULL)P=P->left;else break; 53 } 54 if(a[i]==1){ 55 if(P->left!=NULL) 56 x[i]=1,P=P->left; 57 else if(P->right!=NULL)P=P->right;else break; 58 } 59 } 60 s=0; 61 int i; 62 for(i=0;i<31;i++) if(x[i])break; 63 for(;i<31;i++) if(x[i]) s+=(1<<(31-i-1)); 64 return s; 65 } 66 int main(){ 67 while(~scanf("%d%d",&n,&m)){ 68 int ma=0; 69 T.clear(); 70 memset(x,0,sizeof x); 71 for(int i=0;i<n;i++){ 72 int t; 73 scanf("%d",&t); 74 fun(t); 75 ma=max(ma,dfs()); 76 Add(); 77 } 78 if(ma>m)printf("YES\n");else printf("NO\n"); 79 } 80 return 0; 81 }
浙公网安备 33010602011771号