UOJ #36 -【清华集训2014】玛里苟斯(线性基+暴搜)
看到 \(k\) 次方的期望可以很自然地想到利用低次方和维护高次方和的套路进行处理,不过。由于这里的 \(k\) 达到 \(5\),直接这么处理一来繁琐,二来会爆 long long,因此考虑另辟蹊径。注意到答案 \(\le 2^{63}-1\),也就是说当 \(k\) 比较大时值域也不会太大。因此考虑对 \(k\) 分类讨论。
\(k=1\) 时考虑计算每一位的贡献,注意到对于一位 \(i\),如果存在某个 \(a_j\) 满足 \(a_j\) 的 \(2^i\) 位为 \(1\),那么这一位在子集异或和中为 \(1\) 的概率就是 \(\dfrac{1}{2}\)。否则这一位自然不可能异或出 \(0\) 来,对答案的贡献自然就是 \(0\),贡献随便加一下即可。
\(k=2\) 时考虑用低次方和维护高次方和的套路,假设 \(x=2^{b_1}+2^{b_2}+\cdots+2^{b_k}\),那么显然有 \(x^2=(2^{b_1}+2^{b_2}+\cdots+2^{b_k})^2=\sum\limits_{i=1}^k\sum\limits_{j=1}^k2^{b_i}·2^{b_j}\),也就是说我们考虑每两个在异或和中同时为 \(1\) 的位 \(i,j\),答案加上 \(2^i,2^j\) 在 \(x\) 中同时为 \(1\) 的概率乘上 \(2^{i+j}\) 的和。考虑枚举 \(i,j\) 计算 \(2^i,2^j\) 位在 \(x\) 中同时为 \(1\) 的概率,显然满足不存在任何一个 \(a_p\) 的第 \(i\) 位为 \(1\),或者不存在任何一个 \(a_p\) 的第 \(i\) 位为 \(1\),那么 \(2^i,2^j\) 位在 \(x\) 中同时出现的概率为 \(0\)。否则如果对于任意 \(a_p\) 都有 \(a_p\) 的第 \(i,j\) 位同时为 \(0\) 或者同时为 \(1\),那么 \(2^i,2^j\) 在 \(x\) 中同时出现的概率为 \(\dfrac{1}{2}\),否则 \(2^i,2^j\) 在 \(x\) 中同时出现的概率为 \(\dfrac{1}{4}\),贡献累加一下即可。
\(k\ge 3\) 时我们考虑建出原序列的线性基,显然对于不在线性基中的元素,我们删除它们后答案不会发生变化。由于题目保证了答案 \(\le 2^{63}-1\),因此线性基中的个数不会太多。精确地估算一下大概就 \(\sum\limits_{i=0}^{2^p-1}x^3\) 是关于 \(2^p\) 的四次多项式,再除以一个 \(2^p\) 是关于 \(2^p\) 的三次多项式,当 \(p=22\) 时 \(4194304^3\) 就已经超过了 ull 的范围,就算乘上个小常数也超过了 \(2^{63}\),因此暴搜即可。
可以证明此题答案小数点后最多只有一位,证明大概就仿照 \(k=2\) 的思路,考虑枚举 \(k\) 位 \(b_1,b_2,b_3,\cdots,b_k\),答案加上 \(b_1,b_2,\cdots,b_k\) 位同时为 \(1\) 的概率乘上 \(2^{b_1+b_2+\cdots+b_k}\)。我们假设 \(b_1,b_2,b_3,\cdots,b_k\) 中不同数的个数为 \(c\),那么这些位产生的贡献应是某个整数乘上 \(2^{b_1+b_2+\cdots+b_k-c}\),分析一下可知当 \(b_i=0,c=1\) 时 \(2^{b_1+b_2+\cdots+b_k-c}\) 取到最小值 \(0.5\),因此此题小数点后最多只有一位 0.5。
const int MAXN=1e5;
const int LOG_N=64;
int n,k,flg[LOG_N+2];u64 a[MAXN+5];
void print(u64 x){
printf("%llu",x>>1);
if(x&1) printf(".5");
}
namespace sub{
u64 b[LOG_N+2];
__int128_t res=0;int tot=0;
void insert(u64 x){
for(int i=LOG_N-1;~i;i--) if(x>>i&1){
if(!b[i]) return b[i]=x,void();
x^=b[i];
}
}
void dfs(int x,u64 sm){
if(x==LOG_N+1){
__int128_t mul=1;
for(int i=1;i<=k;i++) mul*=sm;
res+=mul;tot++;return;
} dfs(x+1,sm);
if(b[x]) dfs(x+1,sm^b[x]);
}
void solve(){
for(int i=1;i<=n;i++) insert(a[i]);
dfs(0,0);
if(tot!=1) res/=(tot/2);
else res*=2;
print((u64)res);
}
}
int main(){
scanf("%d%d",&n,&k);
for(int i=1;i<=n;i++) scanf("%llu",&a[i]);
if(k==1){
u64 res=0;
for(int i=0;i<LOG_N;i++){
bool has1=0;
for(int j=1;j<=n;j++) has1|=(a[j]>>i&1);
if(has1) res+=1ull<<i;
} print(res);
} else if(k==2){
u64 res=0;
for(int i=0;i<LOG_N;i++) for(int j=1;j<=n;j++) flg[i]|=(a[j]>>i&1);
for(int i=0;i<LOG_N;i++) for(int j=0;j<LOG_N;j++){
bool sm=1;
if(!flg[i]||!flg[j]) continue;
for(int k=1;k<=n;k++) sm&=(!((a[k]>>i&1)^(a[k]>>j&1)));
if(sm) res+=1ull<<(i+j);
else res+=1ull<<(i+j-1);
} print(res);
} else sub::solve();
return 0;
}
UOJ #36 -【清华集训2014】玛里苟斯(线性基+暴搜)的更多相关文章
- uoj #46[清华集训2014]玄学
uoj 因为询问是关于一段连续区间内的操作的,所以对操作构建线段树,这里每个点维护若干个不交的区间,每个区间\((l,r,a,b)\)表示区间\([l,r]\)内的数要变成\(ax+b\) 每次把新操 ...
- UOJ.41.[清华集训2014]矩阵变换(稳定婚姻)
题目链接 稳定婚姻问题:有n个男生n个女生,每个男/女生对每个女/男生有一个不同的喜爱程度.给每个人选择配偶. 若不存在 x,y未匹配,且x喜欢y胜过喜欢x当前的配偶,y喜欢x也胜过y当前的配偶 的完 ...
- bzoj 3816&&uoj #41. [清华集训2014]矩阵变换
稳定婚姻问题: 有n个男生,n个女生,所有女生在每个男生眼里有个排名,反之一样. 将男生和女生两两配对,保证不会出现婚姻不稳定的问题. 即A-1,B-2 而A更喜欢2,2更喜欢A. 算法流程: 每次男 ...
- uoj 41 【清华集训2014】矩阵变换 婚姻稳定问题
[清华集训2014]矩阵变换 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://uoj.ac/problem/41 Description 给出 ...
- AC日记——【清华集训2014】奇数国 uoj 38
#38. [清华集训2014]奇数国 思路: 题目中的number与product不想冲: 即为number与product互素: 所以,求phi(product)即可: 除一个数等同于在模的意义下乘 ...
- [UOJ#274][清华集训2016]温暖会指引我们前行
[UOJ#274][清华集训2016]温暖会指引我们前行 试题描述 寒冬又一次肆虐了北国大地 无情的北风穿透了人们御寒的衣物 可怜虫们在冬夜中发出无助的哀嚎 “冻死宝宝了!” 这时 远处的天边出现了一 ...
- UOJ#36. 【清华集训2014】玛里苟斯 线性基
原文链接https://www.cnblogs.com/zhouzhendong/p/UOJ36.html 题解 按照 $k$ 分类讨论: k=1 : 我们考虑每一位的贡献.若有至少一个数第 $i$ ...
- uoj#36. 【清华集训2014】玛里苟斯(线性基+概率期望)
传送门 为啥在我看来完全不知道为什么的在大佬们看来全都是显然-- 考虑\(k=1\)的情况,如果序列中有某一个\(a_j\)的第\(i\)位为\(1\),那么\(x\)的第\(i\)位为\(1\)的概 ...
- UOJ #36「清华集训2014」玛里苟斯
这怎么想得到啊......... UOJ #36 题意:求随机一个集合的子集的异或和的$k$次方的期望值,保证答案$ \lt 2^{63},1 \leq k \leq 5$ $ Solution:$ ...
随机推荐
- 《手把手教你》系列技巧篇(三十三)-java+ selenium自动化测试-单选和多选按钮操作-上篇(详解教程)
1.简介 在实际自动化测试过程中,我们同样也避免不了会遇到单选和多选的测试,特别是调查问卷或者是答题系统中会经常碰到.因此宏哥在这里直接分享和介绍一下,希望小伙伴或者童鞋们在以后工作中遇到可以有所帮助 ...
- Less-(38~41) 堆叠注入
首先申明,Less-(38~41)可以采取和Less-(1~4)相同的解法:(一一对应) 然而,他们的漏洞其实更大,我们可以做更多具有破坏性的事情. 代码审计: Less-(38~41): 41的$s ...
- 基于RequestBodyAdvice和ResponseBodyAdvice来实现spring中参数的加密和解密
在日常开发中,有时候我们经常需要和第三方接口打交道,有时候是我们调用别人的第三方接口,有时候是别人在调用我们的第三方接口,那么为了调用接口的安全性,一般都会对传输的数据进行加密操作,如果每个接口都由我 ...
- ASP.NET Core 学习笔记 第四篇 ASP.NET Core 中的配置
前言 说道配置文件,基本大多数软件为了扩展性.灵活性都会涉及到配置文件,比如之前常见的app.config和web.config.然后再说.NET Core,很多都发生了变化.总体的来说技术在进步,新 ...
- HCNP Routing&Switching之BGP路由属性和优选规则
前文我们了解了BGP防环机制和路由聚合相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/15458110.html:今天我们来聊一聊BGP路由属性和选路规 ...
- 架构师之路-redis集群解析
引子 上篇<架构师之路-https底层原理>里我提到了上面的整体视图,文章也介绍了想要真正能在工作中及时正确解决问题的基本功:原理理解透彻.今天以redis集群解析为例介绍一个及时敏锐的发 ...
- 转:Vivado IP报[Opt 31-67] 错误问题解决方法
使用VIVADO编译代码时,其中一个IP报错,错误类似为 ImplementationOpt Design[Opt 31-67] Problem: A LUT2 cell in the design ...
- DeWeb - 物资流转管理系统 - 开发1
近期一个朋友提到要做一个安卓手机上物资流转管理系统 准备采用deweb练练手! 大致的计划是先做成手机版网页,然后加壳做成APP 一. 登录 界面基本设计如下 用户表设计如下: 待续
- APP 自动化之手势操作appium提供API详解(四)
一.手势操作1.上下左右滑屏 swipe---滑动 java-client 4.x 是有swipe方法的,可以通过传递坐标信息就可以完成滑动androidDriver.swipe(startx, st ...
- elasticsearch7.x配置文件
前言: 以下配置文件基于elasticsearch-7.13.4版本,当然也适用于其它7.x版本 集群环境: 部署3个节点的集群,各个节点不做角色区分,既是master,也是data,在性能 上这种方 ...