「ARC 139F」Many Xor Optimization Problems【线性做法,踩标】
「ARC 139F」Many Xor Optimization Problems
对于一个长为 \(n\) 的序列 \(a\),我们记 \(f(a)\) 表示从 \(a\) 中选取若干数,可以得到的最大异或值。
现在给定 \(n,m\),你需要对于所有长为 \(n\),且 \(0\le a_i<2^m\) 的序列,计算 \(f(a)\) 的和。
\(1\le n,m\le 250000\)。
PS:本题解的做法可以做到 \(n=10^9,m=10^7\)。
Solution
考虑给定序列 \(a\),我们计算 \(a\) 的正交线性基,不妨设基底有 \(k\) 个元素,其最高位分别为 \(a_1<a_2<\cdots<a_k\)。显然最大异或值就是这 \(k\) 个元素的异或和。
这启发我们去枚举 \(k\) 以及 \(a_1,\cdots,a_k\) 计算对答案的贡献,贡献由三部分相乘得到:
多少个序列 \(a\),满足它的正交线性基满足基底有 \(k\) 个元素,且最高位分别为 \(a_1,\cdots,a_k\);
这 \(k\) 个元素期望和;
序列 \(a\) 的这 \(k\) 个基底的其他 \(m-k\) 位的填法。
对于第 1 部分,我们先只关心这 \(k\) 个位,考虑如下流程:
- 初始线性基 \(S\) 大小为空;
- 加入 \(a_i\):
- 它与线性基内元素线性相关。那么有 \(2^{|S|}\) 种方案;
- 它与线性基内元素线性无关。那么有 \(2^k-2^{|S|}\) 种方案。
因此,方案为:
\]
容易看出前半部分为经典的 q-binomial,令 \(H(x)=\sum\limits_{k} \binom{n}{k}_2 x^k\),容易递推求出其所有项。
对于第 2 部分,显然这 \(k\) 位必定是 \(1\),其余位都以 \(\frac 1 2\) 的概率是 \(1\),因此期望和为:
\]
对于第 3 部分,由于是正交线性基,因此对于 \(a_j\) 所在的元素而言,所有 \(a_i<a_j\) 的 \(a_i\) 位必须为 \(0\),其他位没限制,因此方案数为:
\]
将三部分相乘,得到:
\]
计算这个式子,我们拆成 \(-1\)、\(\sum\limits_{i=1}^{k}2^{a_i}\)、\(2^{a_k+1}\) 三块分别计算。
- 第一块
显然要的就是 \([x^k]\prod\limits_{i=0}^{m-1}(1+2^ix)\)。
设 \(G(x)=\prod\limits_{i=0}^{m-1} (1+2^ix)\),易知:
\]
对比 \([x^i]\) 项系数得:
\]
可以 \(\mathcal O(m)\) 递推得到。
- 第二块
这次乘上了 \(\sum a_i\) 的贡献,注意到 \(\sum a_i\) 可以看成是 \(2^m-1\) 再减去不在 \(a_i\) 的那些 \(2^i\)。
于是贡献就很显然了,是 \((2^m-1)[x^k]G-(k+1)[x^{k+1}]G\)。
- 第三块
这次乘上了最大值(\(a_k\))的贡献,考虑枚举最大值为 \(mx\):
\(F(x)=\sum\limits_{mx=0}^{m-1}(2^{mx})^2\prod\limits_{i=0}^{mx-1}(1+2^ix)\),易知:
\]
对比 \([x^i]\) 项系数得:
\]
仍可以 \(\mathcal O(m)\) 得到。
因此总时间复杂度 \(\mathcal O(m+\log \text{mod})\)。
参考代码可以见 此 link,我偷懒所以逆元部分写的带 log 了,以及求 \(2^{n}\) 的地方带上了 \(\mathcal O(n)\)。
「ARC 139F」Many Xor Optimization Problems【线性做法,踩标】的更多相关文章
- 「TJOI / HEOI2016」求和 的一个优秀线性做法
我们把\(S(i, j)j!\)看成是把\(i\)个球每次选择一些球(不能为空)扔掉,选\(j\)次后把所有球都扔掉的情况数(顺序有关).因此\(S(i, j)j! = i\cdot b(b+1)\cdot c(c+1)}{8} \] 「ARC 107B」Quadrup ...
- Solution -「ARC 104E」Random LIS
\(\mathcal{Description}\) Link. 给定整数序列 \(\{a_n\}\),对于整数序列 \(\{b_n\}\),\(b_i\) 在 \([1,a_i]\) 中等概率 ...
- Solution -「ARC 101D」「AT4353」Robots and Exits
\(\mathcal{Description}\) Link. 有 \(n\) 个小球,坐标为 \(x_{1..n}\):还有 \(m\) 个洞,坐标为 \(y_{1..m}\),保证上述坐标 ...
- Solution -「ARC 110D」Binomial Coefficient is Fun
\(\mathcal{Description}\) Link. 给定非负整数序列 \(\{a_n\}\),设 \(\{b_n\}\) 是一个非负整数序列且 \(\sum_{i=1}^nb_i\ ...
- Solution -「ARC 124E」Pass to Next
\(\mathcal{Description}\) Link. 有 \(n\) 个人站成一个环,初始时第 \(i\) 个人手里有 \(a_i\) 个球.第 \(i\) 个人可以将自己手中任意数 ...
- Solution -「ARC 126E」Infinite Operations
\(\mathcal{Description}\) Link. 给定序列 \(\{a_n\}\),定义一次操作为: 选择 \(a_i<a_j\),以及一个 \(x\in\mathbb R ...
- Solution -「ARC 126F」Affine Sort
\(\mathcal{Description}\) Link. 给定 \(\{x_n\}\),令 \[f(k)=\left|\{(a,b,c)\mid a,b\in[0,c),c\in[1,k ...
- Solution -「ARC 125F」Tree Degree Subset Sum
\(\mathcal{Description}\) Link. 给定含有 \(n\) 个结点的树,求非负整数对 \((x,y)\) 的数量,满足存在 \(\exist S\subseteq V ...
随机推荐
- throws子句在继承当中overrride时有什么规则
8.throws子句在继承当中overrride时的规则 马克-to-win:当子类方法override父类方法时,throws子句不能引进新的checked异常.换句话说:子类override方法的 ...
- CentOS 7.9 网络配置
vi /etc/sysconfig/network-scripts/ifcfg-ens33 (45条消息) CentOS 7.9 网络配置_$青的博客-CSDN博客_centos7.9网卡配置
- PAT B1024科学计数法
科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][1-9].[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位,小数部分至少有 1 位,该数字及其指 ...
- struts token令牌机制
利用Struts同步令牌(Token)机制来解决Web应用中的重复提交问题.该方法的基本原理是:服务器端在处理到达的request之前,会将request中的Token值与保存在当前用户session ...
- 浅谈ES6中的Class
转载地址:https://www.cnblogs.com/sghy/p/8005857.html 一.定义类(ES6的类,完全可以看做是构造函数的另一种写法) class Greet { constr ...
- docker搭建cordova 11环境
cordova@11 依赖环境: Java_jdk@1.8.0 Nodejs@12.22.9 android-sdk Build-tools 28 API 28 apache-ant@1.10.12 ...
- (动态模型类,我的独创)Django的原生ORM框架如何支持MongoDB,同时应对客户使用时随时变动字段
1.背景知识 需要开发一个系统,处理大量EXCEL表格信息,各种类别.表格标题多变,因此使用不需要预先设计数据表结构的MongoDB,即NoSQL.一是字段不固定,二是同名字段可以存储不同的字段类型. ...
- java生成多级菜单树
使用java实现一个多级菜单树结构 先上数据库 ps_pid字段很重要,是父级菜单的id Menu类 Menu类要新增一个字段,用来存放子菜单 /** * 子菜单列表 */ private List& ...
- Java学习day9
抽象类的关键字:abstract 类中有抽象方法时,需要在类名前也加上abstract关键字,即 public abstract class 类名{ } 同时,抽象类不能直接实例化,需要通过子类继承, ...
- 【课程汇总】OpenHarmony 成长计划知识赋能第三期系列课程(附链接)
OpenHarmony 开源开发者成长计划第三期知识赋能课程硬核程度再次升级,带领开发者上手 OpenHarmony 的标准系统应用开发,学习标准设备应用开发,使用 eTS UI 开发分布式应用样例, ...