【BZOJ3622】已经没有什么好害怕的了(动态规划,容斥)

题面

BZOJ

题解

很明显的,这类问题是要从至少变成恰好的过程,直接容斥即可。

首先我们要求的是(糖果>药片)=(药片>糖果)+k,再加上保证不存在相同的数,

所以(糖果>药片)+(药片>糖果)=n,解出(糖果>药片)=\(\frac{n+k}{2}\)。

此时我们要求的至少就是“至少存在\(i\)对(糖果>药片)的方案数”。

直接算很麻烦,那就\(dp\)算。首先进行排序。

设\(f[i][j]\)表示前\(i\)对中,(糖果>药片)至少为\(j\)的方案数。

那么,转移显然是\(f[i][j]=f[i-1][j]+f[i-1][j-1]*(s-j+1)\)。

至于后面为啥是\(s-j+1\)不就是\(RabbitNumbering\)那题吗。。。

\(k\)是满足糖果\(i\)>药片\(s\),\(s\)的最大值,显然可以\(O(n)\)预处理。

接下来的容斥就比较简单了吧。。。。

至少\(i,i>k\)次会被至少\(k\)次重复计算\(C_i^k\)次,容斥减掉就好了。。。

计算的时候别忘了除了至少匹配的\(j\)对,剩下的\(n-j\)是可以随意匹配的,这个是要乘阶乘的。。

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<algorithm>
  7. using namespace std;
  8. #define ll long long
  9. #define MOD 1000000009
  10. #define MAX 2222
  11. void add(int &x,int y){x+=y;if(x>=MOD)x-=MOD;}
  12. inline int read()
  13. {
  14. int x=0;bool t=false;char ch=getchar();
  15. while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
  16. if(ch=='-')t=true,ch=getchar();
  17. while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
  18. return t?-x:x;
  19. }
  20. int a[MAX],b[MAX],f[MAX][MAX];
  21. int jc[MAX],jv[MAX],inv[MAX];
  22. int n,K;
  23. int C(int n,int m){return 1ll*jc[n]*jv[m]%MOD*jv[n-m]%MOD;}
  24. int main()
  25. {
  26. n=read();K=read();
  27. if((n+K)&1){puts("0");return 0;}
  28. jc[0]=jv[0]=inv[0]=inv[1]=1;
  29. for(int i=1;i<=n;++i)jc[i]=1ll*jc[i-1]*i%MOD;
  30. for(int i=2;i<=n;++i)inv[i]=1ll*inv[MOD%i]*(MOD-MOD/i)%MOD;
  31. for(int i=1;i<=n;++i)jv[i]=1ll*jv[i-1]*inv[i]%MOD;
  32. for(int i=1;i<=n;++i)a[i]=read();
  33. for(int i=1;i<=n;++i)b[i]=read();
  34. sort(&a[1],&a[n+1]);sort(&b[1],&b[n+1]);
  35. f[0][0]=1;
  36. for(int i=1,k=0;i<=n;++i)
  37. {
  38. while(k<n&&b[k+1]<a[i])++k;
  39. for(int j=1;j<=i;++j)
  40. {
  41. add(f[i][j],f[i-1][j]);
  42. add(f[i][j],1ll*f[i-1][j-1]*max(k-j+1,0)%MOD);
  43. }
  44. f[i][0]=f[i-1][0];
  45. }
  46. int d=1,ans=0;K=(n+K)>>1;
  47. for(int i=K;i<=n;++i,d=MOD-d)add(ans,1ll*f[n][i]*d%MOD*C(i,K)%MOD*jc[n-i]%MOD);
  48. printf("%d\n",ans);
  49. return 0;
  50. }

【BZOJ3622】已经没有什么好害怕的了(动态规划,容斥)的更多相关文章

  1. [BZOJ3622] 已经没有什么好害怕的了(dp+容斥)

    Description: ​ 有两个数组a和b,两两配对,求 \(a_i>b_i\) 的配对比 \(b_i>a_i\) 的配对多 \(k\) 个的方案数 \(k\le n\le 2000\ ...

  2. bzoj 3622 已经没有什么好害怕的了 类似容斥,dp

    3622: 已经没有什么好害怕的了 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1213  Solved: 576[Submit][Status][ ...

  3. BZOJ3622 已经没有什么好害怕的了 动态规划 容斥原理 组合数学

    原文链接https://www.cnblogs.com/zhouzhendong/p/9276479.html 题目传送门 - BZOJ3622 题意 给定两个序列 $a,b$ ,各包含 $n$ 个数 ...

  4. P4859-已经没有什么好害怕的了【容斥,dp】

    正题 题目链接:https://www.luogu.com.cn/problem/P4859 题目大意 两个长度为\(n\)的序列\(a,b\)两两匹配,求\(a_i>b_i\)的组数比\(a_ ...

  5. 【BZOJ3622】已经没有什么好害怕的了 容斥+DP

    [BZOJ3622]已经没有什么好害怕的了 Description Input Output Sample Input 4 2 5 35 15 45 40 20 10 30 Sample Output ...

  6. [BZOJ3622]已经没有什么好害怕的了(容斥DP)

    给定两个数组a[n]与b[n](数全不相等),两两配对,求“a比b大”的数对比“b比a大”的数对个数多k的配对方案数. 据说做了这题就没什么题好害怕的了,但感觉实际上这是一个套路题,只是很难想到. 首 ...

  7. BZOJ3622 已经没有什么好害怕的了 【dp + 二项式反演】

    题目链接 BZOJ3622 题解 既已开题 那就已经没有什么好害怕的了 由题目中奇怪的条件我们可以特判掉\(n - k\)为奇数时答案为\(0\) 否则我们要求的就是糖果大于药片恰好有\(\frac{ ...

  8. [bzoj3622]已经没有什么好害怕的了_动态规划_容斥原理

    bzoj-3622 已经没有什么好害怕的了 题目大意: 数据范围:$1\le n \le 2000$ , $0\le k\le n$. 想法: 首先,不难求出药片比糖果小的组数. 紧接着,我开始的想法 ...

  9. bzoj3622已经没有什么好害怕的了

    bzoj3622已经没有什么好害怕的了 题意: 给n个数Ai,n个数Bi,将Ai中的数与Bi中的数配对,求配对Ai比Bi大的比Bi比Ai大的恰好有k组的方案数.n,k≤2000 题解: 蒟蒻太弱了只能 ...

随机推荐

  1. Laya 1.x 按文件夹TS代码合并

    Laya 1.x 使用TS开发时,经常会碰到代码文件太多,加载index.html时时间太长的问题.Laya编辑器貌似没有自带JS代码合并的功能.基于Laya去实现JS合并需要修改编辑器源码,合并JS ...

  2. jenkins的时间与服务器的时间不一致

    解决办法:

  3. sar命令详解

    基础命令学习目录首页 原文链接:http://lovesoo.org/linux-sar-command-detailed.html sar(System Activity Reporter系统活动情 ...

  4. scrapy有用的(代理,user-agent,随机延迟等)

    代理 方法一(待测试) 见scrapy.downloadermiddlewares.httpproxy.HttpProxyMiddleware import os # 设置相应的代理用户名密码,主机和 ...

  5. babel无法编译?

    ECMAScript 6(ES6)的发展或者说普及之快可以说是难以想象的,对很多人来说ECMAScript 5(ES5)都还普及呢.现代浏览器对ES6新特新或多或少的有些支持,但支持度不高,所以要想在 ...

  6. 常用DB2命令

    建库 db2 territory CN on 建库到指定位置 db2 create database OADB on D: using codeset GBK territory CN 列出所有数据库 ...

  7. 2-Eighth Scrum Meeting20151208

    任务分配 闫昊: 今日完成:和唐彬讨论研究上届的网络接口代码. 明日任务:商讨如何迁移ios代码到android平台. 唐彬: 今日完成:和闫昊讨论研究上届的网络接口代码. 明日任务:商讨如何迁移io ...

  8. Java编程题每日一练day1

    Day1共7题 package com.pcx.day1; /** * 设一个字符数组,对其元音字母进行统计 * a e i o u * @author Administrator * */ publ ...

  9. C++ MOOC

    相关课程列表: C++远征之起航篇 C++远征之离港篇 C++远征之封装篇 上 C++远征之封装篇 下 C++远征之继承篇 C++远征之多态篇 授课老师:james_yuan 在寒假,我主要选择 C+ ...

  10. Apache优化之多路处理模块理解

    前言: 当项目被多人访问时导致访问数度变慢,查了许多资料,了解到Apache的核心模块——MPM(多路处理访问模块).在此对MPM的一些知识点进行整理. MPM_WINNT模块 windows系统使用 ...