IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> [HAOI2015] 按位或——Min-Max反演,FWT -> 正文阅读

[C++知识库][HAOI2015] 按位或——Min-Max反演,FWT

[HAOI2015]按位或

题解

按照惯例,我们先进行拆位,每一个二进制位分开考虑,假设第 i i i 位第一次变为1的时间是 f ( i ) f(i) f(i),那么答案就是 E ( max ? { f ( i ) } ) E(\max\{f(i)\}) E(max{f(i)})

这么 max ? \max max 符号在期望的里面,不能直接拿出来,所以最好的处理办法就是对它使用 Min-Max 反演:
E ( max ? i ∈ S { f ( i ) } ) = ∑ T ≠ ? , T ? S ( ? 1 ) ∣ T ∣ ? 1 E ( min ? i ∈ T { f ( i ) } ) E(\max_{i\in S}\{f(i)\})=\sum_{T\neq ?,T\subseteq S}(-1)^{|T|-1}E(\min_{i\in T}\{f(i)\}) E(iSmax?{f(i)})=T?=?,T?S?(?1)T?1E(iTmin?{f(i)})
反演一下就简单多了,我们只需要求出每个集合内第一次出现1的期望时间即可。设 s p S = ∑ T ? S p T sp_S=\sum_{T\subseteq S}p_T spS?=T?S?pT?,那么有
E ( min ? i ∈ S { f ( i ) } ) = s p I ? S 1 ? s p I ? S + 1 = 1 1 ? s p I ? S E(\min_{i\in S}\{f(i)\})=\frac{sp_{I-S}}{1-sp_{I-S}}+1=\frac{1}{1-sp_{I-S}} E(iSmin?{f(i)})=1?spI?S?spI?S??+1=1?spI?S?1?
这个 s p sp sp 用沃尔什变换求一下即可。

代码

今天发现一个巨坑,就是主函数想要用逗号执行一步操作后返回值,如果忘了在后面加,0并且前面部分返回的值正好是int则不会报错,但是运行时会RE

#include<bits/stdc++.h>//JZM yyds!!
#define ll long long
#define uns unsigned
#define IF (it->first)
#define IS (it->second)
#define END putchar('\n')
using namespace std;
const int MAXN=1048581;
const ll INF=1e18;
inline ll read(){
	ll x=0;bool f=1;char s=getchar();
	while((s<'0'||s>'9')&&s>0){if(s=='-')f^=1;s=getchar();}
	while(s>='0'&&s<='9')x=(x<<1)+(x<<3)+(s^48),s=getchar();
	return f?x:-x;
}
int ptf[50],lpt;
inline void print(ll x,char c='\n'){
	if(x<0)putchar('-'),x=-x;
	ptf[lpt=1]=x%10;
	while(x>9)x/=10,ptf[++lpt]=x%10;
	while(lpt)putchar(ptf[lpt--]^48);
	if(c>0)putchar(c);
}
inline ll lowbit(ll x){return x&-x;}

int n,g[MAXN];
const double eps=1e-9;
double p[MAXN],ans;
signed main()
{
	n=read();
	for(int s=0;s<(1<<n);s++)scanf("%lf",p+s);
	for(int k=0;k<n;k++)
		for(int s=0;s<(1<<n);s++)
			if((s>>k)&1)p[s]+=p[s^(1<<k)];
	g[0]=-1;
	for(int s=1;s<(1<<n);s++)g[s]=(s&1)?-g[s>>1]:g[s>>1];
	for(int s=1,lim=(1<<n)-1;s<=lim;s++){
		if(1-p[lim^s]<eps)return printf("INF\n"),0;//就是这里
		ans+=1.0*g[s]/(1-p[lim^s]);
	}
	printf("%.10f\n",ans);
	return 0;
}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-30 18:05:26  更:2022-03-30 18:07:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:45:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码