Atcoder Grand Contest 038 E - Gachapon(Min-Max 容斥+背包)
我竟然能独立做出 Ag 的 AGC E,incredible!更新了 Atcoder 做题难度上限(
首先按照套路 Min-Max 容斥,\(ans=\sum\limits_{\varnothing\ne T\subseteq S}(-1)^{|T|-1}\times E(\min(T))\),考虑怎样求这个式子的值。首先我们需要搞清楚 \(E(\min(T))\),假设 \(T\) 中包含下标为 \(x_1,x_2,\cdots,x_m\) 这 \(m\) 个元素,那么 \(E(\min(T))\) 的实际意义就是期望最少选多少个数就能找到一个 \(x_i\) 的出现次数达到了其上界 \(b_{x_i}\),首先有可能我们抽到的数不在 \(T\) 当中,这里有一个小套路,我们记 \(e\) 为期望多少次才能抽到一个 \(T\) 中的数,那么显然 \(e=\dfrac{\sum a_i}{\sum\limits_{x\in T}a_x}\),这样相当于我们将原来每一步的贡献 \(1\) 变成了 \(e\),因此我们只需将答案乘个 \(e\) 就可以得到最终的 \(E(\min(T))\)。这样一来我们就不用考虑不在 \(T\) 中的数的影响了,不过我们发现这东西是不太好直接求的,故我们不妨换个角度,我们假设到达最终状态时元素 \(x_i\) 被选择的 \(c_i\) 次,那么不难发现对于任意一个由初始状态 \(0,0,\cdots,0\) 到达最终状态的取数方式,它中间总要经过 \(\sum c_i\) 个满足 \(c_i<b_{x_i}\) 的状态,因此我们可以在每个中间状态中累加一次贡献,而对于一个满足 \(\forall i,c_i<b_{x_i}\) 的 \(c_1,c_2,\cdots,c_m\),只要它到达了这个状态,它就肯定会被统计入答案中,因此我们要求的实际上是所有满足满足 \(\forall i,c_i<b_{x_i}\) 的 \(c_1,c_2,\cdots,c_m\),到达 \(c_1,c_2,\cdots,c_m\) 的概率。而显然对于固定的 \(c_1,c_2,\cdots,c_m\),到达 \(c_1,c_2,\cdots,c_m\) 的概率可用总方案数除以到达 \(c_1,c_2,\cdots,c_m\) 的方案数计算,即 \(\dfrac{(\sum c_i)!}{\prod c_i!}\times\prod(\dfrac{a_i}{\sum\limits_{x\in S}a_x})^{c_i}\),第一项为多重组合数,即将 \(i\) 个 \(c_i\) 填入一排 \(c_1+c_2+\cdots+c_m\) 个数的方案数,第二项表示生成 \(c_i\) 个 \(i\) 的方案数,生成一个 \(i\) 的概率为 \(\dfrac{a_i}{\sum\limits_{x\in S}a_x}\),生成 \(c_i\) 个 \(i\) 的概率就是 \((\dfrac{a_i}{\sum\limits_{x\in S}a_x})^{c_i}\),很好理解。
因此我们有:
\]
将其带入答案计算式可得
\]
注意到 \(\sum a_i\) 是定值,\(\sum\limits_{x\in T}a_x,\sum c_i\) 都不会超过 \(400\),因此考虑 \(dp\),可以将其放入背包的状态中,设 \(dp_{i,j,k}\) 表示所有 \(T\subseteq\{1,2,3,\cdots,i\}\),\(\sum\limits_{x\in T}a_x=j\),\(\sum c_i=k\) 的 \((-1)^{|T|-1}\prod\dfrac{1}{c_i!}a_i^{c_i}\) 的和,转移就分 \(i\in T\) 和 \(i\notin T\) 转移即可,若 \(i\notin T\) 则 \(dp_{i,j,k}\leftarrow dp_{i-1,j,k}\),否则我们枚举 \(c_i<b_i\),那么 \(dp_{i,j,k}\leftarrow -dp_{i-1,j,k}\times\dfrac{1}{c_i!}a_i^{c_i}\),二者相加即可,初始值 \(dp_{0,0,0}=-1\)(因为空集的 \((-1)^{|T|+1}=-1\)),求答案就枚举 \(\sum\limits_{x\in T}a_x=j,\sum c_i=k\),然后用 \(dp_{n,j,k}\times(\sum a_i)\times\dfrac{1}{j^{k+1}}\times k!\) 更新答案即可,第一维可以优化到,时间复杂度 \(\sum a_i(\sum b_i)^2\),空间复杂度 \(\sum a_i\sum b_i\),可以通过此题。
const int MAXN=400;
const int MOD=998244353;
int n,a[MAXN+5],b[MAXN+5],sa,sb,dp[MAXN+5][MAXN+5];
int inv[MAXN+5],ifac[MAXN+5],fac[MAXN+5];
void init_fac(int n){
for(int i=(inv[0]=inv[1]=ifac[0]=fac[0]=1)+1;i<=n;i++) inv[i]=1ll*inv[MOD%i]*(MOD-MOD/i)%MOD;
for(int i=1;i<=n;i++) ifac[i]=1ll*ifac[i-1]*inv[i]%MOD,fac[i]=1ll*fac[i-1]*i%MOD;
}
int main(){
scanf("%d",&n);init_fac(MAXN);dp[0][0]=MOD-1;
for(int i=1;i<=n;i++) scanf("%d%d",&a[i],&b[i]),sa+=a[i],sb+=b[i];
for(int i=1;i<=n;i++){
for(int j=sa;j>=a[i];j--) for(int k=sb;~k;k--)
for(int l=0,pw=1;l<=min(k,b[i]-1);l++,pw=1ll*pw*a[i]%MOD){
dp[j][k]=(dp[j][k]-1ll*dp[j-a[i]][k-l]*pw%MOD*ifac[l]%MOD+MOD)%MOD;
}
} int ans=0;
for(int i=1;i<=sa;i++) for(int j=0,pw=1;j<=sb;j++,pw=1ll*pw*inv[i]%MOD){
ans=(ans+1ll*dp[i][j]*pw%MOD*inv[i]%MOD*sa%MOD*fac[j]%MOD)%MOD;
} printf("%d\n",ans);
return 0;
}
Atcoder Grand Contest 038 E - Gachapon(Min-Max 容斥+背包)的更多相关文章
- AtCoder Grand Contest 038 简要题解
从这里开始 比赛目录 Problem A 01 Matrix Code #include <bits/stdc++.h> using namespace std; typedef bool ...
- AtCoder Grand Contest 038 题解
传送门 这场表现的宛如一个\(zz\) \(A\) 先直接把前\(b\)行全写成\(1\),再把前\(a\)列取反就行 const int N=1005; char mp[N][N];int n,m, ...
- AtCoder Grand Contest 038题解
好久没更了 写点东西吧= = A 01Matrix 简单构造 左上角和右下角染成1其他染成0即可 #include<bits/stdc++.h> #define ll long long ...
- Atcoder Grand Contest 038 F - Two Permutations(集合划分模型+最小割)
洛谷题面传送门 & Atcoder 题面传送门 好久前做的题了--今天偶然想起来要补个题解 首先考虑排列 \(A_i\) 要么等于 \(i\),要么等于 \(P_i\) 这个条件有什么用.我们 ...
- AtCoder Grand Contest 038
目录 \(\bf A - 01 \ Matrix\) \(\bf B- Sorting \ a \ Segment\) \(\bf C-LCMs\) \(\bf D-Unique \ Path\) 这 ...
- AtCoder Grand Contest 012
AtCoder Grand Contest 012 A - AtCoder Group Contest 翻译 有\(3n\)个人,每一个人有一个强大值(看我的假翻译),每三个人可以分成一组,一组的强大 ...
- AtCoder Grand Contest 011
AtCoder Grand Contest 011 upd:这篇咕了好久,前面几题是三周以前写的... AtCoder Grand Contest 011 A - Airport Bus 翻译 有\( ...
- AtCoder Grand Contest 031 简要题解
AtCoder Grand Contest 031 Atcoder A - Colorful Subsequence description 求\(s\)中本质不同子序列的个数模\(10^9+7\). ...
- AtCoder Grand Contest 010
AtCoder Grand Contest 010 A - Addition 翻译 黑板上写了\(n\)个正整数,每次会擦去两个奇偶性相同的数,然后把他们的和写会到黑板上,问最终能否只剩下一个数. 题 ...
随机推荐
- javascript的变量及数据类型
1.变量的概念 变量是储存数据的内存空间 2.变量的命名规则 js变量的命名规则如下:以字母或者下划线开头可以包含字母.数字.下划线,不能包含特殊字符 3.变量的创建及初始化方法 方法一:先创建后使用 ...
- .NET 事件总线,简化项目、类库、线程、服务等之间的通信,代码更少,质量更好。
Jaina .NET 事件总线,简化项目.类库.线程.服务等之间的通信,代码更少,质量更好. 安装 Package Manager Install-Package Jaina .NET CLI do ...
- OO_JAVA_四个单元的总结
总结本单元两次作业的架构设计 设计目标 尽量减少特殊容器的存在,能通用就通用,减少重复的类同代码. 基础容器的存在,就是为上述目标而服务的. 设计概要 底层:基础的.类型无关.无依赖的容器以及对应的查 ...
- Noip模拟29(瞎眼忌) 2021.8.3
T1 最长不下降子序列 在此记录自己的瞎眼... 考场上像一个傻$der$,自己为了防范上升序列和不下降序列的不同特意的造了一组$hack$数据来卡自己:(第一行是序列长度,第二行是序列) 6 1 5 ...
- 嵌入式开发板nfs挂载
板子要开始调试了,第一个头大的问题就是调试过程中更新的文件怎么更新到板子上,以前用sd卡拷贝来来回回太浪费时间了,adb也需要接线各种连接操作. 现在板子有wifi可用,是时候把nfs共享搭起来了. ...
- 连续子序列的最大和 牛客网 剑指Offer
连续子序列的最大和 牛客网 剑指Offer 题目描述 HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学.今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量 ...
- oracle 数据库修改端口号1521
1.关闭监听 2.修改配置文件,port=1933 #vi $ORACLE_HOME/network/admin/listener.ora 3.登录并查看local_listener参数,因为使用的是 ...
- SimpleNVR流媒体服务在多分屏直播实时阅览时所遇到问题的解决
视频有一个流的概念,称为流媒体.当大量的客户端或WEB访问监控摄像机的时候,大多数的录像机无法承受那么大的网络压力,这时候SimpleNVR流媒体服务器的优势就显示出来了.其能将客户端的访问压力转到服 ...
- k8s入坑之路(7)kubernetes设计精髓List/Watch机制和Informer模块详解
1.list-watch是什么 List-watch 是 K8S 统一的异步消息处理机制,保证了消息的实时性,可靠性,顺序性,性能等等,为声明式风格的API 奠定了良好的基础,它是优雅的通信方式,是 ...
- 开源项目|Go 开发的一款分布式唯一 ID 生成系统
原文连接: 开源项目|Go 开发的一款分布式唯一 ID 生成系统 今天跟大家介绍一个开源项目:id-maker,主要功能是用来在分布式环境下生成唯一 ID.上周停更了一周,也是用来开发和测试这个项目的 ...