P4859 已经没有什么好害怕的了(dp+二项式反演)
如果你看不太懂二项式反演(比如我)
那么只需要记住:对于某两个$g(i),f(i)$
----------------------------
如果:$f(n)=\sum_{i=0}^{n}C(n,i)g(i)$
那么:$g(n)=\sum_{i=0}^{n}(-1)^{n-i}\ C(n,i)f(i)$
----------------------------
如果:$f(k)=\sum_{i=k}^{n}C(i,k)g(i)$
那么:$g(k)=\sum_{i=k}^{n}(-1)^{i-k}\ C(i,k)f(i)$
糖果比药片能量大的组数比“药片”比“糖果”能量大的组数多k组。看起来很麻烦
设“药片”比“糖果”能量大的组数为$x$
$x+(x-k)=n$
解得$x=(n+k)/2$,所以$n+k$为奇数一定是没有方案的
现在问题转化成:“药片”比“糖果”能量大的组数为$(n+k)/2$的方案数
看看数据$O(n^2)$可过,想着搞个dp
先将$A[i],B[i]$小到大排好序
蓝后设$f[i][j]$表示(从小到大)扫到$A[i]$(第$i$个),并配好$j$对的方案数
再预处理好$l[i]$表示$B$数组中有多少个数小于$A[i]$
分为不配对或配对的情况,列出方程
$f[i][j]=f[i-1][j]+max(0,l[i]-j+1)*f[i-1][j-1]$
$dp$完了,现在我们来考虑$f[n][i](0<=i<=n)$有啥用(大雾)
对于每个$f[n][i]$,剩下没配对的$n-i$个可以随便排序(注意随便排序可能又配出合法对,有重复计算)
于是我们设个$g(i)$表示$n$个数合法配对数$>=i$的排列方案数
$g(i)=f[n][i]*(n-i)!$
但是我们要求的是合法配对数$==i$的排列方案数鸭
设个$f(i)$表示所求↑↑↑
显然对于每个$g(k)\ and\ f(i)\ \ (i>=k)$
$g(k)$都加了$C(i,i-k)=C(i,k)$个$f(i)$进去
于是我们就得到了$g(k)$关于$f(i)$的表达式
$g(k)=\sum_{i=k}^{n}C(i,k)f(i)$
仔细一看,这不是可以套二项式反演吗!
$f(k)=\sum_{i=k}^{n}(-1)^{i-k}\ C(i,k)g(i)$
蓝后就可以愉快地把$f(k)$算出来辣
注意$mod=1e9+9$(不是$1e9+7$)TAT
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long ll;
#define N 2010
const ll P=1e9+;
int n,k,A[N],B[N],l[N];
ll f[N][N],g[N],inv[N],fac[N],ifac[N],ans;
void prep(){
inv[]=; fac[]=fac[]=ifac[]=ifac[]=;
for(ll i=;i<=n;++i){
inv[i]=(P-P/i)*inv[P%i]%P;
fac[i]=fac[i-]*i%P;
ifac[i]=ifac[i-]*inv[i]%P;
}
}
inline ll C(int a,int b){return fac[a]*ifac[b]%P*ifac[a-b]%P;}
int main(){
scanf("%d%d",&n,&k);
if((n+k)&){puts(""); return ;}
k=(n+k)/; prep();
for(int i=;i<=n;++i) scanf("%d",&A[i]);
for(int i=;i<=n;++i) scanf("%d",&B[i]);
sort(A+,A+n+); sort(B+,B+n+); int tmp=;
for(int i=;i<=n;++i){
while(tmp<n&&B[tmp+]<A[i]) ++tmp;
l[i]=tmp;
}f[][]=;
for(int i=;i<=n;++i){
f[i][]=f[i-][];
for(int j=;j<=i;++j)
f[i][j]=(f[i-][j]+1ll*(l[i]-j+)*f[i-][j-])%P;
}
for(int i=;i<=n;++i) g[i]=f[n][i]*fac[n-i]%P;
for(int i=k;i<=n;++i)
ans=((ans+1ll*(((i-k)&)?-:)*C(i,k)*g[i])%P+P)%P;
printf("%lld",ans);
return ;
}
P4859 已经没有什么好害怕的了(dp+二项式反演)的更多相关文章
- BZOJ3622 已经没有什么好害怕的了 【dp + 二项式反演】
题目链接 BZOJ3622 题解 既已开题 那就已经没有什么好害怕的了 由题目中奇怪的条件我们可以特判掉\(n - k\)为奇数时答案为\(0\) 否则我们要求的就是糖果大于药片恰好有\(\frac{ ...
- 洛谷P4859 已经没有什么好害怕的了 [DP,容斥]
传送门 思路 大佬都说这是套路题--嘤嘤嘤我又被吊打了\(Q\omega Q\) 显然,这题是要\(DP\)的. 首先思考一下性质: 为了方便,下面令\(k=\frac{n+k}{2}\),即有恰好\ ...
- 题解-洛谷P4859 已经没有什么好害怕的了
洛谷P4859 已经没有什么好害怕的了 给定 \(n\) 和 \(k\),\(n\) 个糖果能量 \(a_i\) 和 \(n\) 个药片能量 \(b_i\),每个 \(a_i\) 和 \(b_i\) ...
- 洛谷 P4859 已经没有什么好害怕的了 解题报告
已经没有什么好害怕的了 题目描述 已经使\(\tt{Modoka}\)有签订契约,和自己一起战斗的想法后,\(\tt{Mami}\)忽然感到自己不再是孤单一人了呢. 于是,之前的谨慎的战斗作风也消失了 ...
- BZOJ 3622 Luogu P4859 已经没有什么好害怕的了 (容斥原理、DP)
题目链接 (Luogu) https://www.luogu.org/problem/P4859 (bzoj) https://www.lydsy.com/JudgeOnline/problem.ph ...
- BZOJ 3622 : 已经没有什么好害怕的了(dp + 广义容斥原理)
今天没听懂 h10 的讲课 但已经没有什么好害怕的了 题意 给你两个序列 \(a,b\) 每个序列共 \(n\) 个数 , 数之间两两不同 问 \(a\) 与 \(b\) 之间有多少配对方案 使得 \ ...
- luoguP4859 已经没有什么好害怕的了(二项式反演)
luoguP4859 已经没有什么好害怕的了(二项式反演) 祭奠天国的bzoj. luogu 题解时间 先特判 $ n - k $ 为奇数无解. 为了方便下记 $ m = ( n + k ) / 2 ...
- P4859 已经没有什么好害怕的了
传送门 见计数想容斥 首先题目可以简单转化一下, 求 糖果比药片能量大的组数比药片比糖果能量大的组数多 $k$ 组 的方案数 因为所有能量各不相同,所以就相当于求 糖果比药片能量大的组数为 $(n+k ...
- luogu P4859 已经没有什么好害怕的了
嘟嘟嘟 题中给的\(k\)有点别扭,我们转换成\(a > b\)的对数是多少,这个用二元一次方程解出来是\(\frac{n + k}{2}\). 然后考虑dp,令\(dp[i][j]\)表示前\ ...
随机推荐
- Selenium 3----窗口截图+关闭浏览器
窗口截图 get_screenshot_as_file() 自动化用例是由程序执行的,因此有时候打印的错误信息并不十分明确.如果在脚本执行出错的时候能对当前窗口截图保存,那么通过图片就可以非常直观地看 ...
- QQ设置手机和pc qq群消息不同步
作为开发人员QQ群很多,很正常,工作的时候才需要看qq信息和群消息,但是蛋疼qq在新版的qq必须设置同步,之前用的qq8.1版本可以设置不同步,但是现在突然不行 目前可以用的途径就是 QQ国际PC版2 ...
- 解决:vue项目中多个echarts图表只有最后一个随浏览器变化改变大小
window.onresize = () => { this.initChart()} 改为 window.addEventListener('resize', () => { this. ...
- verilog 之流水灯
1.黑金板 简易操作: 通过判断数值累加 个人观点:黑金代码质量有待提高,讲解不够详细 2.正点原子的 位置调换 led[:] <= {led[:],led[]}; 3.传统位移 led& ...
- 报文分析6、ARP报头结构
ARP报头结构 硬件类型 协议类型 硬件地址长度 协议长度 操作类型 发送方的硬件地址(0-3字节) 源物理地址(4-5字节) 源IP地址(0-1字节) 源IP地址(2-3字节) 目标硬件地址(0 ...
- VMware+CentOS7学习记录
CentOS命令记录 1.su root 进入最高权限 2.cd /位置 即进入该文件 3.中文与英文之间的切换:win+空格 添加中文的步骤:https://blog.csdn.net ...
- oracle_dataGuard_11G
[李红]--切记_从库只安装实例_不需要 dbca 创建数据库 但是 netca 创建监听看个人喜欢,我反正是创建了.[DataGuard_主数据库的参数配置]1.启用 force logging 功 ...
- CF1139D Steps to One
题目链接:洛谷 这个公式可真是个好东西.(哪位大佬知道它叫什么名字的?) 如果$X$恒$\geq 0$,那么 $$E[X]=\int_0^{+\infty}P(X>t)dt$$ 呸,我什么都没写 ...
- Linux内核内存管理算法Buddy和Slab: /proc/meminfo、/proc/buddyinfo、/proc/slabinfo
slabtop cat /proc/slabinfo # name <active_objs> <num_objs> <objsize> <objpersla ...
- webpack4.27.1中遇到的错误
1:ERROR in Entry module not found: Error: Can't resolve './src' 我在使用webpack命令时报错,这时因为我的配置文件有问题webpac ...