【BZOJ3622】已经没有什么好害怕的了 容斥+DP
【BZOJ3622】已经没有什么好害怕的了
Description
.jpg)
Input
.jpg)
Output
.jpg)
Sample Input
5 35 15 45
40 20 10 30
Sample Output
HINT
.jpg)
输入的2*n个数字保证全不相同。
题解:好吧这题不是神题,而是套路题,容斥+DP的套路在很多题中都用到过,不过我虽然知道套路,却被这题的第一步卡住了。
我们将两个序列从小到大排序。
好吧这步看起来可能很水,正常人看到无序的序列都会先想到排序,然而为什么要两个都从小到大排呢?排序的意义何在?一会讲。
题中给的是(糖果>药片)=(药片>糖果)+k,我们只需要用一点小学数学的知识就能算出(糖果>药片)的具体数量。下面是套路部分:我们设f[i][j]表示枚举到前i个,(糖果>药片)数至少为j的方案数。然后我们预处理出最大的k,满足药片k<糖果i,那么方程就是:
$f[i][j]=f[i-1][j]+f[i-1][j-1]*(k-j+1)$
现在知道排序的意义了吧?因为后面的i的决策区间一定包含前面的i的决策区间,所以只需要将其减去即可防止重复。
那么最后答案是什么呢?套路:ans=至少有k个的方案数-至少有k+1个的+至少有k+2个的方案数-。。。
所以答案=$\sum\limits_{j=k}^nf[n][j](-1)^{j-k}C_j^k$
P.S:这里解释一下容斥系数是$C_j^k$的原理吧,首先我们用f[i]代表上面的f[n][i],用g[i]代表恰好有i个符合条件的方案数。根据定义有:$f[i]=\sum\limits_{j=i}^ng[i]C_j^i$。所以我们上面得到的最终式子可以转化成:$\sum\limits_{j=k}^nf[j](-1)^{j-k}C_j^k=\sum\limits_{i=k}^ng[i]\sum\limits_{j=k}^i(-1)^{j-k}C_i^jC_j^k\\=\sum\limits_{i=k}^ng[i]\sum\limits_{j=k}^i(-1)^{j-k}C_i^kC_{i-k}^{j-k}\\=\sum\limits_{i=k}^ng[i]C_i^k\sum\limits_{j=k}^i(-1)^{j-k}C_{i-k}^{j-k}$
根据组合恒等式后面那个东西只在i=k的时候=1,其余时候=0,所以我们就得到了g[k]。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long ll;
const ll P=1000000009;
int n,m;
ll ans;
ll f[2010][2010],c[2010][2010],jc[2010];
int a[2010],b[2010];
inline int rd()
{
int ret=0,f=1; char gc=getchar();
while(gc<'0'||gc>'9') {if(gc=='-') f=-f; gc=getchar();}
while(gc>='0'&&gc<='9') ret=ret*10+(gc^'0'),gc=getchar();
return ret*f;
}
int main()
{
n=rd(),m=rd();
if((n^m)&1)
{
printf("0");
return 0;
}
m=(n+m)>>1;
int i,j,k;
for(jc[0]=i=1;i<=n;i++) jc[i]=jc[i-1]*i%P;
for(i=1;i<=n;i++) a[i]=rd();
for(i=1;i<=n;i++) b[i]=rd();
for(i=0;i<=n;i++)
{
c[i][0]=1;
for(j=1;j<=i;j++) c[i][j]=(c[i-1][j-1]+c[i-1][j])%P;
}
sort(a+1,a+n+1),sort(b+1,b+n+1);
f[0][0]=1;
for(i=1;i<=n;i++)
{
for(k=1;k<=n&&b[k]<a[i];k++);
k--;
for(j=1;j<=i;j++) f[i][j]=(f[i-1][j]+f[i-1][j-1]*max(k-j+1,0))%P;
f[i][0]=f[i-1][0];
}
ll tmp=1;
for(i=m;i<=n;i++) f[n][i]=(f[n][i]*jc[n-i])%P,ans=(ans+tmp*f[n][i]*c[i][m]%P+P)%P,tmp=-tmp;
printf("%lld",(ans+P)%P);
return 0;
}
【BZOJ3622】已经没有什么好害怕的了 容斥+DP的更多相关文章
- [BZOJ3622]已经没有什么好害怕的了(容斥DP)
给定两个数组a[n]与b[n](数全不相等),两两配对,求“a比b大”的数对比“b比a大”的数对个数多k的配对方案数. 据说做了这题就没什么题好害怕的了,但感觉实际上这是一个套路题,只是很难想到. 首 ...
- BZOJ3622 已经没有什么好害怕的了 二项式反演+DP
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=3622 题解 首先显然如果 \(n - k\) 为奇数那么就是无解.否则的话,"糖果& ...
- BZOJ3622(容斥+dp)
思路 "恰k个"考虑求至少k.k+1--个容斥 题面说所有数字都不同,可以将所求转化为糖比药多的组数恰为\((n+k)/2\)的方案数 \(f[i][j]\)数组我觉得更好的理解方 ...
- P4859-已经没有什么好害怕的了【容斥,dp】
正题 题目链接:https://www.luogu.com.cn/problem/P4859 题目大意 两个长度为\(n\)的序列\(a,b\)两两匹配,求\(a_i>b_i\)的组数比\(a_ ...
- 【BZOJ3622】已经没有什么好害怕的了(动态规划,容斥)
[BZOJ3622]已经没有什么好害怕的了(动态规划,容斥) 题面 BZOJ 题解 很明显的,这类问题是要从至少变成恰好的过程,直接容斥即可. 首先我们要求的是(糖果>药片)=(药片>糖果 ...
- BZOJ3622 已经没有什么好害怕的了 【dp + 二项式反演】
题目链接 BZOJ3622 题解 既已开题 那就已经没有什么好害怕的了 由题目中奇怪的条件我们可以特判掉\(n - k\)为奇数时答案为\(0\) 否则我们要求的就是糖果大于药片恰好有\(\frac{ ...
- [bzoj3622]已经没有什么好害怕的了_动态规划_容斥原理
bzoj-3622 已经没有什么好害怕的了 题目大意: 数据范围:$1\le n \le 2000$ , $0\le k\le n$. 想法: 首先,不难求出药片比糖果小的组数. 紧接着,我开始的想法 ...
- bzoj3622已经没有什么好害怕的了
bzoj3622已经没有什么好害怕的了 题意: 给n个数Ai,n个数Bi,将Ai中的数与Bi中的数配对,求配对Ai比Bi大的比Bi比Ai大的恰好有k组的方案数.n,k≤2000 题解: 蒟蒻太弱了只能 ...
- bzoj3622已经没有什么好害怕的了 dp+组合+容斥(?)
3622: 已经没有什么好害怕的了 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1033 Solved: 480[Submit][Status][ ...
随机推荐
- API 版本控制的几种方式
个人建议:用content type,即放在Header里面!比如加一个Version:1.4.3 这篇文章写得很好,介绍了三种实现web api版本化的三种方式.我从评论里又收集到两种方式,所以一共 ...
- vue组件调用(用npm安装)
vue用webpack打包方式新建项目,注意刚开始可以先关闭路由和代码错误检测功能 1.建立了一个Hi.vue的组件 <template> <div>Hi~~{{msg}}-- ...
- informix-時間格式的各種用法
以下是我在網路上所收集到的關於informix 時間的sql函數用法,有在使用informix資料庫的人,可以參考看看囉! today,返回現在系統日期 current 返回現在日期含時間,相當於sq ...
- 安卓API首页
http://developer.android.com/reference/packages.html
- Atitit.解决org.hibernate.DuplicateMappingException: Duplicate class/entity mapping
Atitit.解决org.hibernate.DuplicateMappingException: Duplicate class/entity mapping 1. 排除流程::: @Depreca ...
- 通达OA 几次通过OA进行的足球抢票活动确实对OA系统提出了非常大挑战
今年集团赞助了中超的足球比赛,有比赛的时候会提前发一些球票.怎么发.发给谁这就是一个问题.后来确定通过OA来抢票. 通过在OA上发表帖子.通过信息提醒.大家看到信息提示后在帖子后面回复,依据回复先后确 ...
- 479. Second Max of Array【easy】
Find the second max number in a given array. Notice You can assume the array contains at least two n ...
- [转]T-SQL_面试题
[转]T-SQL_面试题 2015-05-19 1 创建表插入数据 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,s ...
- 16位结构的CPU,8086给出物理地址的方法
.16位结构的CPU 概括地讲,16位结构(16位机,字长为16位等常见说法,与16位结构的含义相同)描述了一个CPU具有下面几方面结构特性: 1.运算器一次最多可以处理16位的数据结构 2.寄存器的 ...
- 在eclipse上Checkstyle的安装和使用
1. 概述 随着中心的代码规范的建立和实施,项目组对代码规范要求,以及软件工程师们对自身代码的编写规范重要性的认知,“代码规范”已经成为了中心的一个“热词”.然后怎么才能写出有规范的代码,怎么才能养成 ...