洛谷P3812 【模板】线性基
任意选取元素,求最大异或和,就用线性基。
1 //不用高斯消元求线性基 2 #include<bits/stdc++.h> 3 using namespace std; 4 typedef long long ll; 5 const int M=63; 6 ll p[M];//线性基 7 bool zero; 8 9 void Insert(ll x){ 10 for(int i=M;i>=0;i--) 11 if(x>>i==1)//x的最高位 12 if(p[i]==0){p[i]=x;return ;}//p[i]还没有,p[i]=x 13 else x^=p[i];//p[i]已经有了,逐个异或 14 zero=true; //A有异或和为0的组合 15 } 16 17 ll qmax(){ 18 ll ans=0; 19 for(int i=M;i>=0;i--) ans=max(ans,ans^p[i]); 20 return ans; 21 } 22 23 int main(){ 24 ll x;int n;scanf("%d",&n); 25 for(int i=1;i<=n;i++) scanf("%lld",&x),Insert(x); 26 printf("%lld\n",qmax()); 27 return 0; 28 }
p[i]存的是二进制下有i位的数。
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
标签:
线性基
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!