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 }

 

 
posted @ 2017-08-17 00:08  樱花落舞  阅读(266)  评论(0编辑  收藏  举报