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 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 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的设计差异
· 三行代码完成国际化适配,妙~啊~