【学习笔记】线性基

news/2025/10/16 16:48:54/文章来源:https://www.cnblogs.com/LinkyChristian/p/19146056

模拟赛遇到一个笨比线性基题但是忘了怎么求编号......最后因读入T掉来不及修改赛后20s过题,惨痛教训。

线性基是一组极小的用于表达一个数集异或空间的基底。其满足以下性质:

1.能由原数集异或得到的任意一个数,线性基中都有且仅有一个子集能表示它。

2.由1得,线性基中不存在一个数能被其它元素异或得到。

3.由2得,线性基中不存在异或和为 $0$ 的子集。

线性基不是唯一的,且不一定需要满足最高位互不相同,但我们构造时需要构造一个最高位互不相同的线性基,这样才能在加入元素时通过贪心判断新元素能否被原线性基表达。

假设我们已经有了一个最高位互不相同的线性基,现在加入一个新元素:

  • 如果不使用最高位与新元素最高位相同的基向量,那么其它所有向量无论如何组合也无法凑出最高位的 $1$,因此必定使用最高位与新元素最高位相同的基向量。

  • 对于新出现的最高位,重复以上操作。

显然不论我们以任何顺序插入元素,线性基大小都相同,得到以下性质:所有线性基大小相同,即对一个数集求线性无关的基底则其大小固定。

由此,我们构造线性基的代码已经可以写出来了:

for(int k=50; k>=0; k--) {    		if(num&(1ll<<k)) {    			if(!p[k]) {p[k]=num;break;}    			num^=p[k];    		
}

$num$ 为新插入的数,$p_k$ 为最高位为 $k$ 的基向量。

拓展:如何求原数集子集异或和的集合大小?

显然线性基的任意一个子集的异或和都不相同,所以其为 $2^{线性基大小}$

拓展:线性基构造出来的数,如何输出原数集中的对应方案?

我们对线性基中的每一个数用一个 bitset 记录其是由原数集中的哪些数异或得到的。具体而言:

bitset<N> pid[55];
for(int i=1; i<=n; i++) {cin>>a[i];bitset<N> id; id[i]=1;  for(int k=50; k>=0; k--) {    		if(a[i]&(1ll<<k)) {    			if(!p[k]) {p[k]=a[i],pid[k]=id;break;}    			a[i]^=p[k],id^=pid[k];    		}
}

用线性基构造时,使用的基向量的 $pid$ 异或和即为对应的原数集集合。

线性基的用处:

1.判断某个数是否可以被原数集的某个子集异或得到。

与往线性基中加数相同。

进阶: 判断某个数被原数集的某个子集异或得到的方案数。

任何数被线性基异或得到的方案数唯一,考虑没能加入线性基的数有 $k$ 个,显然这 $k$ 个数任选一个子集都能用线性基中的一个子集使其贡献为 $0$ ,因而每个数会有 $2^k$ 中表达方法

2.判断原数集异或能得到的最大/最小值。

从高位到低位贪心,若该位为 $0$ 且存在最高位为此位的基向量,则异或此基向量即可。

for(int i=50; i>=0; i--) if(!(ans&(1ll<<i))) ans^=p[i];

进阶:判断原数集异或能得到的第 $k$ 小值。

显然对于某个存在最高位为该位的位,我们都可以自由控制该位是否为 $1$ 。

因此如果我们设置该位为 $1$ ,则增加了 $2^{最高位低于该位的基向量个数}$ 个小于它的数。

ll ans=0,p=cnt;
for(Reg int i=62;i>=0;--i){if(!b[i]) continue;if(ans&(1ll<<i)){if(k>(1ll<<(p-1))) k-=(1ll<<(p-1)),ans^=b[i];}else{if(k>(1ll<<(p-1))) k-=(1ll<<(p-1));else ans^=b[i];}--p;
}

拓展:对于不去重的排名,考虑没能加入线性基的数有 $k$ 个,显然这 $k$ 个数任选一个子集都能用线性基中的一个子集使其贡献为 $0$ ,因而每个数会重复 $2^k$ 次,若原答案为 $ans$ ,则不去重的答案为 $2^{ans-1}+1$ 。

3.求一个数在原数集异或和中的排名。

与上类似,先判断该数能否被线性基表达出来,再依次枚举每位线性基中存在的位,加上 $2^{最高位低于该位的基向量个数}$ 即可。

带删除线性基

首先需要知道每个时间点都干了些什么,如果是加了个数就需要预处理出这个数会在哪里被删掉。处理好这个之后,我们仍然按照时间处理操作,但是需要给插入线性基的数一个时间戳表示这个数被删除的时间,查询的时候只查询时间戳在当前时间之后的。对于线性基的每一位,时间戳应优先保留靠后的一个。

constexpr int MAXN=5e5+5;
int n,a[MAXN],del[MAXN];
unordered_map<int,int>mp;
struct{int p[32],t[32];void ins(int x,int tim){for(int i=30;~i;i--){if(!(x>>i)) continue;if(tim>t[i]) swap(x,p[i]),swap(tim,t[i]);if(!tim) return;x^=p[i];}}int ask(int tim){int res=0;for(int i=30;~i;i--) if(tim<t[i]) res=max(res,res^p[i]);return res;}
}LB;int main(){n=read();for(int i=1;i<=n;i++){a[i]=read();if(a[i]>0) mp[a[i]]=i,del[i]=n+1;else del[mp[-a[i]]]=i;}for(int i=1;i<=n;i++){if(a[i]>0) LB.ins(a[i],del[i]);write(LB.ask(i));}return fw,0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/938355.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

rest_framework框架视图集整理

from rest_framework.generics import GenericAPIView from rest_framework.request import Request from rest_framework import filters from rest_framework import mixins from rest_framework import generics fr…

x86_64架构__rdtsc指令

__rdtsc指令用于读取处理器的时间戳计数器,该计数器计算自上次复位以来的时钟周期数。这对性能监控和基准测试非常有用。 以下示例为linux环境上Demo#include <stdio.h> #include <x86intrin.h> #include…

AT_joisc2021_c フードコート (Foodcourt)

换维扫描线好题。 发现删除操作会出现过删(即删除的个数大于序列中元素数),这个很难处理。 思考一下应该能想到将每次询问查询的 \(b\to cnt_{del}+b\) 其中 \(cnt_{del}\) 为在该询问之前这个序列删除的数的个数,…

SPP question regarding Issues Due To Gaming Spoofers

Checking SPP Registry Key [Incorrect ModuleId Found]在windows下遇到该问题时,或许可以考虑导入如下的注册表文件。 下载 SPP ref: Issues Due To Gaming Spoofers

类型安全ORM的高并发场景解决方案 - 实践

类型安全ORM的高并发场景解决方案 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "M…

L06_mybatis读取MySQL数据库(懵逼版)

由于上课完全听不懂,又不会java,经过三天折磨,查阅各种网站,总算解决了,一个,,,,,小小小小作业。 1.创建一个项目,如果IDEA为2024版,左上角File-》new-》Project按照上面图片配置就好了。 2.需要加载的依赖…

提供给第三方接口的验证方法

第三方调用(认证方式时效限制5分钟)该 postman 调用 url 为样例 url请求头: AuthorizationBasicMTIzOmRjOTg0ZDY4NzJjNWZkYWFkZDllZDg4ZGE5ZmU5ZDYwZDc40TkxMzA0NWFmNjhkMjNiMzE4NzUzZTRhYTIWMDU= 请求头: Timestamp20…

【2025最新】6款免费DLL修复工具推荐:彻底解决“XXX.dll缺失”问题!

系统频繁弹出“XXX.dll缺失”提示?本文汇总6款2025年最新免费DLL修复工具,包括金山毒霸电脑医生、迅捷DLL助手、360安全卫士等,一键扫描自动修复系统缺失DLL,支持Win7/10/11,让你的电脑秒恢复稳定运行。电脑运行时…

2025 年注浆管生产厂家最新推荐排行榜:聚焦 0.3mm 精度与国企合作案例,助力基建企业精准挑选优质供应商

在基建工程中,注浆管是保障防渗加固、隧道支护等环节安全的关键材料,其质量直接决定工程使用寿命与施工安全。当前市场上,部分厂家为压缩成本,选用低强度钢材、忽视品控,导致管材抗压不足、壁厚不均,频繁出现破裂…

vue 下拉框 vxe-select 实现人员选择下拉列表

vue 下拉框 vxe-select 实现人员选择下拉列表 使用自定义选项插槽的方式,可以灵活的实现各种类型的下拉选择 官网:https://vxeui.com github:https://github.com/x-extends/vxe-pc-ui gitee:https://gitee.com/x-e…

双核A53+开源生态,ZX7981P Wi-Fi6 5G插卡路由器开发板CPE内核新选择!

双核A53+开源生态,ZX7981P Wi-Fi6 5G插卡路由器开发板CPE内核新选择!在物联网技术飞速发展的今天,一款出色的开发平台能够极大加速产品研发进程。启明智显推出的ZX7981P Wi-Fi6 5G插卡路由器开发板,正是为高效开发…

2025 高效过滤器制造企业最新推荐榜:供货商定制方案深度解析及口碑评级

在环保水处理与空气净化行业升级提速的背景下,精密过滤器的定制适配性直接决定项目达标效率与运营成本。当前市场呈现 “两极分化” 态势:老牌企业虽经验丰富,但部分定制方案创新不足;新兴品牌虽灵活度高,却因缺乏…

最后防线 解题报告

简要题意 给定一棵 \(n\) 个节点的有根树,每个点有点权 \(a\)。求出一个访问顺序,使得所有点都在其祖先之后被访问,设第 \(i\) 个节点是第 \(p_i\) 个被访问到的,最小化 \(\sum \limits_{1\ le i \le n}p_ia_i\)。…

2025 年试验箱厂家 TOP 企业品牌推荐排行榜,氙灯老化 / 紫外老化 / 冷热冲击 / 恒温恒湿 / 高低温 / 快速温变 / 盐水喷雾 / 高温老化 / 砂尘 / 淋雨试验箱公司推荐!

2025 年试验箱厂家 TOP 企业品牌推荐排行榜,氙灯老化 / 紫外老化 / 冷热冲击 / 恒温恒湿 / 高低温 / 快速温变 / 盐水喷雾 / 高温老化 / 砂尘 / 淋雨试验箱公司推荐!引言在现代工业生产与科研活动中,试验箱作为模拟…

系统修复

cmd中文显示异常:chcp 936 (临时方法)打开控制面板--时钟和区域--区域--管理--更改系统区域设置-当前系统区域设置为中文(简体中国) 查看上一次是什么应用程序唤醒了电脑可以以管理员模式启动命令提示符(CMD),…

什么是vibe ?

这里的 “vibe” 不是指普通的 “氛围”,而是结合 AI 工作场景的一种直观感受,核心是AI 自主、流畅执行任务的 “状态感” 或 “体验感”。 它之所以用 “vibe” 这个偏感性的词,是为了突出和传统方式的差异,具体可…

2025年10月试验箱厂家最新推荐排行榜:氙灯老化试验箱,紫外老化试验箱,冷热冲击试验箱,恒温恒湿试验箱公司推荐!

在工业生产与科研领域,试验箱是验证产品环境适应性、保障质量的关键设备,其性能直接关系到检测数据准确性与研发效率。当前市场上,部分试验箱品牌存在元器件劣质、稳定性差、售后响应慢、功能单一等问题,让企业在选…

AI时代我们需要更多开发者:Shalini Kurapati的技术洞察

在AI已能编写25%代码的今天,Clearbox AI CEO Shalini Kurapati提出我们需要更多而非更少的开发者。她指出AI加速编码的同时也增加了漏洞、偏见和难以追踪的错误风险,强调需要人类专家设计架构、验证输出并构建可靠系…

新一代虚拟助手AI技术挑战赛启动

某中心推出Alexa Prize SimBot挑战赛,旨在通过持续学习、可教导AI、多模态理解和推理等通用AI方法,开发能够协助完成现实世界任务的新一代虚拟助手技术。某中心推出全新Alexa Prize SimBot挑战赛 某中心今日宣布推出…

经典视觉跟踪算法的MATLAB实现

经典视觉跟踪算法的MATLAB实现一、光流法(Lucas-Kanade) 原理:通过像素亮度恒定假设计算相邻帧间的运动矢量场 ​​应用​​:运动目标检测、视频压缩 ​​核心参数​​:窗口大小、金字塔层数、迭代次数 %% 光流法…