[BZOJ 3811]玛里苟斯:线性基(详细证明)

2024-01-10 18:59

本文主要是介绍[BZOJ 3811]玛里苟斯:线性基(详细证明),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(点击这里查看原题

极其复杂的题目……看了一早上题解才看懂
分类讨论
k=1时,考虑每一位对答案的影响,若至少存在一个数第j位为1,那么异或和中第j位为1的概率为0.5,否则为零。因为取到奇数个第j位为1的数的概率和取到偶数个的概率相等。
k=2时,把异或和转化为2进制,那么每个异或和的平方为 ∑ i ∑ j b i b j ∗ 2 i + j \sum _{i} \sum _{j}b_{i}b_{j}*2^{i+j} ijbibj2i+j,那么考虑第i位和第j位的积的期望值。如果所有的a[]中,第i位和第j位均相等且非全零,那么参考k=1的情况,期望为1/2;否则,i为1的概率为1/2,j位1的概率为1/2,i*j为1的概率为1/4。
k>=3时,因为答案不超过263,因此a[i]不会超过221,线性基不会超过21个,于是求出线性基后暴力枚举。
需要注意的是,答案不会溢出,但中间过程可能会,因此需要将y变成 ⌊ y 2 m ⌋ ∗ 2 m + y m o d 2 m \left \lfloor \frac{y}{2^{m}} \right \rfloor*2^{m}+y\; mod \; 2^{m} 2my2m+ymod2m的形式。
这里需要证明一下 ⌊ x k 2 m ⌋ ∗ x + ⌊ ( x k m o d 2 m ) ∗ x 2 m ⌋ = ⌊ x k + 1 2 m ⌋ \left \lfloor \frac{x^{k}}{2^{m}} \right \rfloor*x+\left \lfloor \frac{(x^{k}\; mod\; 2^{m})*x}{2^{m}} \right \rfloor=\left \lfloor \frac{x^{k+1}}{2^{m}} \right \rfloor 2mxkx+2m(xkmod2m)x=2mxk+1
x k = a ∗ 2 m + b ( b < 2 m ) x^{k}=a*2^{m}+b\; (b< 2^{m}) xk=a2m+b(b<2m)
于是等式左边 = a x + ⌊ b x 2 m ⌋ =ax+\left \lfloor \frac{bx}{2^{m}} \right \rfloor =ax+2mbx
等式右边 = ⌊ x k ∗ x 2 m ⌋ = ⌊ a x ∗ 2 m + b x 2 m ⌋ = a x + ⌊ b x 2 m ⌋ =\left \lfloor \frac{x^{k}*x}{2^{m}} \right \rfloor=\left \lfloor \frac{ax*2^{m}+bx}{2^{m}} \right \rfloor=ax+\left \lfloor \frac{bx}{2^{m}} \right \rfloor =2mxkx=2max2m+bx=ax+2mbx
等式左右相等,即证。

/*
User:Small
Language:C++
Problem No.:3811
*/
#include<bits/stdc++.h>
#define ll long long
#define ull unsigned ll
#define inf 999999999
using namespace std;
const int M=1e5+5;
int n,q;
ull a[M],b[65];
void solve1(){ull res=0;for(int i=1;i<=n;i++) res|=a[i];printf("%llu",res>>1);if(res&1) printf(".5");printf("\n");
}
void solve2(){ull ans=0,res=0;for(int i=32;i>=0;i--){for(int j=32;j>=0;j--){bool flag=0;for(int k=1;k<=n;k++)if(a[k]>>i&1){flag=1;break;}if(!flag) continue;flag=0;for(int k=1;k<=n;k++)if(a[k]>>j&1){flag=1;break;}if(!flag) continue;flag=0;for(int k=1;k<=n;k++)if((a[k]>>i&1)!=(a[k]>>j&1)){flag=1;break;}if(i+j-1-flag<0) res++;//只有 (i,j)=(0,0)或(0,1)时有可能出现这种情况,//(i,j)=(0,0)时flag一定为0,因此对答案的影响是(1/2)*(2^0)=1/2;//(i,j)=(0,1)且flag=1时,对答案的影响是(1/4)*(2^1)=1/2。//因此出现这种情况时答案加1/2 else ans+=1LL<<(i+j-1-flag);//flag=0,则为1/2,flag=1,则为1/4 }}ans+=res>>1;printf("%llu",ans);if(res&1) printf(".5");printf("\n");
}
void solve3(){vector<ull> g;int cnt=0;for(int i=1;i<=n;i++){for(int j=22;j>=0;j--){if(a[i]>>j&1){if(b[j]) a[i]^=b[j];else{b[j]=a[i];cnt++;g.push_back(a[i]);break;}}}}ull ans=0,res=0;for(int i=0;i<(1<<cnt);i++){ull val=0;for(int j=0;j<cnt;j++) if(i>>j&1) val^=g[j];ull a=0,b=1;for(int j=0;j<q;j++){a*=val,b*=val;a+=b>>cnt,b&=(1<<cnt)-1;//对b取模 }ans+=a,res+=b;ans+=res>>cnt,res&=(1<<cnt)-1;}printf("%llu",ans);if(res) printf(".5");printf("\n");
}
int main(){freopen("data.in","r",stdin);//scanf("%d%d",&n,&q);for(int i=1;i<=n;i++) scanf("%llu",&a[i]);if(q==1) solve1();else if(q==2) solve2();else solve3();return 0;
}

这篇关于[BZOJ 3811]玛里苟斯:线性基(详细证明)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/591762

相关文章

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Java中HashMap的用法详细介绍

《Java中HashMap的用法详细介绍》JavaHashMap是一种高效的数据结构,用于存储键值对,它是基于哈希表实现的,提供快速的插入、删除和查找操作,:本文主要介绍Java中HashMap... 目录一.HashMap1.基本概念2.底层数据结构:3.HashCode和equals方法为什么重写Has

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

MySQL中优化CPU使用的详细指南

《MySQL中优化CPU使用的详细指南》优化MySQL的CPU使用可以显著提高数据库的性能和响应时间,本文为大家整理了一些优化CPU使用的方法,大家可以根据需要进行选择... 目录一、优化查询和索引1.1 优化查询语句1.2 创建和优化索引1.3 避免全表扫描二、调整mysql配置参数2.1 调整线程数2.

Java实现TXT文件导入功能的详细步骤

《Java实现TXT文件导入功能的详细步骤》在实际开发中,很多应用场景需要将用户上传的TXT文件进行解析,并将文件中的数据导入到数据库或其他存储系统中,本文将演示如何用Java实现一个基本的TXT文件... 目录前言1. 项目需求分析2. 示例文件格式3. 实现步骤3.1. 准备数据库(假设使用 mysql

MySQL 临时表创建与使用详细说明

《MySQL临时表创建与使用详细说明》MySQL临时表是存储在内存或磁盘的临时数据表,会话结束时自动销毁,适合存储中间计算结果或临时数据集,其名称以#开头(如#TempTable),本文给大家介绍M... 目录mysql 临时表详细说明1.定义2.核心特性3.创建与使用4.典型应用场景5.生命周期管理6.注

在 Spring Boot 中连接 MySQL 数据库的详细步骤

《在SpringBoot中连接MySQL数据库的详细步骤》本文介绍了SpringBoot连接MySQL数据库的流程,添加依赖、配置连接信息、创建实体类与仓库接口,通过自动配置实现数据库操作,... 目录一、添加依赖二、配置数据库连接三、创建实体类四、创建仓库接口五、创建服务类六、创建控制器七、运行应用程序八