2017 Multi-University Training Contest - Team 7 Just do it
题意:一次操作就是i从1~n有 A[i]=A[i]^A[i-1]^A[i-2]...^A[1] 那么这样操作m次会得到什么
解法:
我们先打一个表
5 10 1 2 3 4 5 1 3 0 4 1 1 2 2 6 7 1 3 1 7 0 1 2 3 4 4 1 3 0 4 0 1 2 2 6 6 1 3 1 7 1 1 2 3 4 5 1 3 0 4 1 1 2 2 6 7
我们看出...1 2和1 2 3和1 2 3 4会在某一次进行保留,比如10次操作会保留1 2两个数..
于是大胆的想法:保留的数字个数和m&(-m)==ans有关
那么剩下的数字呢,第三个数字2是有1^3得到的,第四个数字是2^4得到的,于是大胆的想法A[i]=A[i]^A[i-ans]
于是就按照大胆的想法写,接下来m-ans继续来一次
1 #include<bits/stdc++.h> 2 using namespace std; 3 int mp[1010]; 4 int x[423456]; 5 int n,m; 6 int sum; 7 map<int,int>Ma,Mp; 8 int main(){ 9 int t; 10 scanf("%d",&t); 11 while(t--){ 12 scanf("%d%d",&n,&m); 13 for(int i=1;i<=n;i++){ 14 scanf("%d",&x[i]); 15 } 16 while(m){ 17 int ans=m&(-m); 18 for(int i=ans+1;i<=n;i++){ 19 x[i]^=x[i-ans]; 20 } 21 m-=ans; 22 } 23 for(int i=1;i<=n;i++){ 24 if(i==n){ 25 printf("%d\n",x[i]); 26 }else{ 27 printf("%d ",x[i]); 28 } 29 } 30 } 31 return 0; 32 }