线性基总结
线性基
定义
基:
线性基:
三大性质
线性基的构造方法
代码实现
ll d[65];
void addnum(ll x)
{
for(int i=60;i>=0;i--)
if((x>>i)&1){
if(d[i])x^=d[i];
else{
d[i]=x;
break;
}
}
}
性质的证明:
证明性质1
分类讨论一下
综上,性质一得证
证明性质2
由反证法:
性质三证明略
应用
求异或最大值
ll getmax()
{
ll res=0;
for(int i=60;i>=0;i--)
if(res^d[i]>res)
res^=d[i];
return res;
}
求异或最小值
ll getmin()
{
ll res=0,cnt=0;
for(int i=60;i>=0;i--)
if(d[i])
cnt++,res=d[i];
if(cnt<n)return 0;
return res;
}
求异或第k大值
例题 : https://vjudge.net/problem/HDU-3949
AC代码:
#include <bits/stdc++.h>
typedef long long ll;
using namespace std;
const int N=1e5+5;
ll d[65],d2[65],cnt;
void addnum(ll x)
{
for(int i=60;i>=0;i--)
if((x>>i)&1){
if(d[i])x^=d[i];
else{
d[i]=x;
break;
}
if(x==0)break;
}
}
void change()
{
for(int i=60;i>=0;i--)
{
for(int j=i-1;j>=0;j--)
if((d[i]>>j)&1){
d[i]^=d[j];
}
}
for(int i=0;i<=60;i++){
if(d[i])d2[cnt++]=d[i];
}
}
int main()
{
int _;
scanf("%d",&_);
for(int t=1;t<=_;t++)
{
memset(d,0,sizeof d);
cnt=0;
printf("Case #%d:\n",t);
int n;
scanf("%d",&n);
for(int i=1;i<=n;i++){
ll x;
scanf("%lld",&x);
addnum(x);
}
change();
int q;
scanf("%d",&q);
for(int i=1;i<=q;i++){
ll k;
scanf("%lld",&k);
if(n>cnt)k--;
if(k>=(1ll<<cnt))printf("-1\n");
else{
ll res=0;
for(int i=0;i<cnt;i++){
if(1&(k>>i))res^=d2[i];
}
printf("%lld\n",res);
}
}
}
return 0;
}
分类:
线性基
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现