题目

这可算是描述很简单的一道题了!但是不简单。

\(S\)是一个可重集合,\(S = \{a_1, a_2, \dots, a_n \}\)。
等概率随机取\(S\)的一个子集\(A = \{a_{i_1}, \dots, a_{i_m}\}\)。
计算出\(A\)中所有元素异或\(x\), 求\(x^k\)的期望。

要点

要点 1

所有异或出来的不同结果的数量是同样多的(这句话可能有点不清楚)。
我的意思是说,假如异或出来的结果有\(5\)、\(3\)、\(4\),那么结果是\(5\)的异或方案数量是等于结果是\(3\)的异或方案数量的,也是等于结果是\(4\)的异或方案数量的。

除此之外,如果
设异或结果为\(0\)的子集(包括空集)数量为\(n\),那么如果异或出来的结果有\(x\),那么一定恰好有\(n\)种方案使得异或出来的结果是\(x\)。

要点 2 \(a_i\)的大小

设其大小为\(2^m-1\),说白了就是化成二进制后有多少位。

那么\[(2^m-1)^k \leqslant answer < 2^{63}\]
即\[2^{mk} \leqslant 2^{63}\]
就是\[m \leqslant \frac {63} {k}\]

算法

算法 1

根据要点1,很容易想到高斯消元。消元后直接暴力即可,不过这个时间复杂度是 \(O(2^m)\)。只能通过\(60 \%\)的数据。

算法 2

设\(P = \lbrace a_1, a_2, \dots, a_{2^n} \rbrace\),它的元素就是\(A\)中所有元素异或,所以它的大小为\(2^n\)。

那么答案为\[\frac {\sum_{i=1}^{2^n} {{a_i}^k}} {2^n}\]

由于\(a_i\)化成二进制后位数比较少,所以用\(b_{i,j}\)表示\(a_i\)化成二进制后的第\(j\)位。

那么答案可以写成\[\frac {\sum_{i=1}^{2^n} ({{\sum_{j=0}^{m} { b_{i,j} \cdot 2^j }}})^k} {2^n}\]

现在假设\(k=2\),有:\[\frac {\sum_{i=1}^{2^n} ({{\sum_{j=0}^{m} \sum_{p=0}^{m} {} { b_{i,j} \cdot b_{i,p} \cdot 2^{j+p} }}})} {2^n}\]

也就是:\[\sum_{j=0}^{m} \sum_{p=0}^{m}( \frac {\sum_{i=1}^{2^n} { b_{i,j} \cdot b_{i,p} }} {2^n}\cdot 2^{j+p})\]

对于\(\frac {\sum_{i=1}^{2^n} { b_{i,j} \cdot b_{i,p} }} {2^n}\),是可以在\(O(n)\)的时间复杂度内算出来的!如果\(j=p\),那么这个值为第\(j\)为\(1\)的概率,如果\(j\neq p\),那么这个值为第\(j\)和第\(p\)同时为\(1\)的概率,这个用一个迭代可以算出(根据要点1,算出最终所有可能出现的异或结果,这里的异或结果是指第\(j\)位和第\(p\),只有4种结果)。

当\(k \neq 2\)时,原理一样!

这样子,我们就可以在\(O(m^k \cdot (n + (2^k)^3))\)内算出\(answer\)了。

k m 总复杂度(估算)
1 63 63
2 31 61504
3 21 4741632
4 15 207360000
5 12 8153726976

好吧,你会发现迭代的时间复杂度有点高!事实上可以利用高斯消元后的独立数进行推导同时出现\(1\)的概率。

这样的话,时间复杂度就是\(O(m^k \cdot m)\)了。

转载于:https://www.cnblogs.com/wangck/p/4187488.html

清华集训2014 day1 task1 玛里苟斯相关推荐

  1. 玛里苟斯[清华集训2014 Day1]

    玛里苟斯[清华集训2014 Day1] 魔法之龙玛里苟斯最近在为加基森拍卖师的削弱而感到伤心,于是他想了一道数学题. S 是一个可重集合,S={a1,a2,-,an}. 等概率随机取 S 的一个子集  ...

  2. 清华集训2014 day2 task1 简单回路

    题目 如题. 算法 就是刚学习的插头DP. 从前往后和从后往前分别进行一次DP. 要点 合法的括号序列只有103个 如何合并两次dp的信息 一开始犯傻了,以为当且仅当两个轮廓线的状态相同才是合法的方案 ...

  3. 清华集训2014 玛里苟斯

    清华集训2014 玛里苟斯 求子集异或和k次方的期望. 异或考虑按位算贡献. 对于\(K=1\),考虑异或和\(\frac{x}{2}\)就是答案. 证明简单来说就是,你可以先打一个概率\(dp\)分 ...

  4. 【清华集训 2014】玛里苟斯(组合计数 + 线性基)

    题目链接:[清华集训 2014]玛里苟斯 推荐博客:[BZOJ 3811]玛里苟斯:线性基(详细证明) 首先想到将kkk分类讨论. k=1" role="presentation& ...

  5. 【清华集训2014】Sum)(类欧几里得算法)

    [清华集训2014]Sum 然后本质上我们需要求解的就是那个带根号式子的奇偶性,然后我们发现这个式子很像是类欧几里得算法,求解一个斜率为无理数直线下的整点个数,然后我们直接对于一般形式求解,那么就是每 ...

  6. 【清华集训2014】【BZOJ3811】玛里苟斯

    Description 魔法之龙玛里苟斯最近在为加基森拍卖师的削弱而感到伤心,于是他想了一道数学题. S 是一个可重集合,S={a1,a2,-,an}. 等概率随机取 S 的一个子集 A={ai1,- ...

  7. [UOJ]#36. 【清华集训2014】玛里苟斯 线性基+分类讨论

    题意: 魔法之龙玛里苟斯最近在为加基森拍卖师的削弱而感到伤心,于是他想了一道数学题. SSS 是一个可重集合,S=a1,a2,-,anS={a1,a2,-,an}S=a1,a2,-,an. 等概率随机 ...

  8. [清华集训2014]玛里苟斯

    一.题目 点此看题 二.解法 注意到答案是2632^{63}263次方,可以分kkk来讨论: k=1k=1k=1,求出所有值或起来的值,每一位有12\frac{1}{2}21​的概率有贡献,所以把这个 ...

  9. 【清华集训2014】玛里苟斯

    看到这道题,然后便错误地联想到了数位DP什么的--接着发现了答案在一个界内,然后就想着暴力了. 首先如果对每一位都设一个变量的话,根据插板法,最多只能有1e7个项对答案有贡献,和答案在一个界内这个条件 ...

最新文章

  1. 2021年高考模拟考成绩查询,2021年湖北省普通高考模拟考试成绩查询
  2. 计算机英语缩写AGP,IT行业常用计算机缩略语
  3. 从零开始搭建基于CEFGlue的CB/S的winform项目
  4. 剑指offer 算法 (画图让抽象问题形象化)
  5. bootstrap select多选
  6. linux脚本日期时间,Linux 日期和时间操作详解
  7. Django从理论到实战(part12)--应用命名空间和实例命名空间
  8. MySQL触发器 trigger学习
  9. java 编译 器 ide_在没有IDE的情况下编译和运行Java
  10. 线程故事:关于健壮的线程池
  11. Java多线程基础总结
  12. cf 189B - Counting Rhombi
  13. DPDK - mlx5 drop action 性能 patch
  14. A_A03_001 stc-isp 单片机烧录软件安装与使用
  15. docker容器无法使用top命令
  16. OSChina 周四乱弹 ——程序员为啥要买苹果手机啊?
  17. SH-SSS丨CUSIDE:分块、模拟未来、解码的流式语音识别新框架
  18. 杨凌职业技术学院计算机专业宿舍,杨凌职业技术学院宿舍怎么样
  19. C语言习题11.3,用指针数组编程输出月份的英文表示
  20. 大数据应用技术课程教学改革与实践

热门文章

  1. 王伟storm_危机中复苏 2005年中国星际风云录
  2. linux修复fat文件系统,如何修复损坏的FAT32文件系统
  3. make_unique的使用
  4. 通俗易懂了解50个IT专业术语
  5. 继戴姆勒之后 德国公司Bury就汽车通信相关专利授权投诉诺基亚
  6. setfocus属性
  7. 如何在win10系统上改装高仿MAC主题桌面
  8. 一个字都没写,也能发Nature子刊?
  9. 电商产品展示,选360°全景还是3D展示?
  10. JavaScript前台判空