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 @   樱花落舞  阅读(268)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示