题目链接

\(Description\)

  有\(n\)个数,用其中的某些数构成集合,求构造出\(m\)个互不相同且非空的集合(\(m\)个集合无序),并满足每个数总共出现的次数为偶数的方案数。

\(Solution\)

  为简化问题,将无序转为有序,只需在最后除以\(m!\)即可。

  设\(f[i]\)表示构造前\(i\)个集合并满足条件的方案数。

  每个数出现次数为偶数,所以如果前\(i-1\)个集合确定,第\(i\)个集合也可以确定。这样对于\(i\)有\(A_{2^n-1}^{i-1}\)种方案,即从所有非空集合中确定\(i-1\)个集合。

  但是会有非法情况,比如这样得到的第\(i\)个集合为空,那么说明前\(i-1\)个集合已经满足条件,这样的方案数是\(f[i-1]\),减掉。

  也有可能得到的第\(i\)个集合与之前某个集合\(j\)重复,那么去掉\(i,j\)后得到的会是合法方案,即\(f[i-2]\),而第\(i/j\)个集合的选取有\(2^n-1-(i-2)\)种可能,\(j\)集合的位置有\(i-1\)种可能,所以减去\(f[i-2]*(i-1)*[2^n-1-(i-2)]\)。

  这样所有限制都处理完了。

  递推式:\(f[i]=A_{2^n-1}^{i-1}-f[i-1]-f[i-2]*(i-1)*[2^n-1-(i-2)]\)

  为什么不能用组合做而要化成排列呢。。

  我觉得是后面枚举的集合情况与前面不一定无序吧。。

  求解答。。

//4728kb	404ms
#include <cstdio>
#include <algorithm>
#define P (100000007)
#define Mul(a,b) (1ll*(a)*(b)%P)
#define Sub(a,b) (a<b ? (a)-(b)+P : (a)-(b))//()!
const int N=1e6+5; int n,m,f[N]; inline int FP(int x,int k)
{
int t=1;
for(; k; k>>=1, x=Mul(x,x))
if(k&1) t=Mul(t,x);
return t;
} int main()
{
scanf("%d%d",&n,&m);
int pw2=FP(2,n)-1;//if(!pw2) pw2=P-1; else --pw2; f[0]=1, f[1]=0;
for(int i=2,Alas=pw2; i<=m; ++i)
{
f[i]=(Alas-f[i-1]+P-1ll*f[i-2]*(i-1)%P*Sub(pw2,i-2)%P+P)%P;
Alas=Mul(Alas, Sub(pw2+1,i));//别去用数组存A[]了。。
}
int inv=1;
for(int i=2; i<=m; ++i) inv=Mul(inv,i);
inv=FP(inv,P-2);
printf("%lld",Mul(f[m],inv)); return 0;
}

BZOJ.2339.[HNOI2011]卡农(思路 DP 组合 容斥)的更多相关文章

  1. bzoj 2339: [HNOI2011]卡农

    Description Solution 比较难想.... 我们先考虑去掉无序的这个条件,改为有序,最后除 \(m!\) 即可 设 \(f[i]\) 表示前\(i\)个合法集合的方案数 明确一点: 如 ...

  2. bzoj3622已经没有什么好害怕的了 dp+组合+容斥(?)

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

  3. 2339: [HNOI2011]卡农

    Description 首先去除顺序不同算一种的麻烦,就是最后答案除以总片段数\(2^m-1\) 设\(f_i\)表示安排\(i\)个片段的合法种类 那么对于任何一个包含\(i-1\)个片段的序列(除 ...

  4. bzoj3294[Cqoi2011]放棋子 dp+组合+容斥

    3294: [Cqoi2011]放棋子 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 755  Solved: 294[Submit][Status] ...

  5. bzoj2339[HNOI2011]卡农 dp+容斥

    2339: [HNOI2011]卡农 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 842  Solved: 510[Submit][Status][ ...

  6. [HNOI2011]卡农 (数论计数,DP)

    题面 原题面 众所周知卡农是一种复调音乐的写作技法,小余在听卡农音乐时灵感大发,发明了一种新的音乐谱写规则. 他将声音分成 n n n 个音阶,并将音乐分成若干个片段.音乐的每个片段都是由 1 1 1 ...

  7. P3214 [HNOI2011]卡农

    题目 P3214 [HNOI2011]卡农 在被一题容斥\(dp\)完虐之后,打算做一做集合容斥这类的题了 第一次深感HNOI的毒瘤(题做得太少了!!) 做法 求\([1,n]\)组成的集合中选\(m ...

  8. 【BZOJ2339】[HNOI2011]卡农 组合数+容斥

    [BZOJ2339][HNOI2011]卡农 题解:虽然集合具有无序性,但是为了方便,我们先考虑有序的情况,最后将答案除以m!即可. 考虑DP.如果我们已经知道了前m-1个集合,那么第m个集合已经是确 ...

  9. [BZOJ2339][HNOI2011]卡农

    [BZOJ2339][HNOI2011]卡农 试题描述 输入 见"试题描述" 输出 见"试题描述" 输入示例 见"试题描述" 输出示例 见& ...

随机推荐

  1. C++的各种初始化方式

    C++小实验测试:下面程序中main函数里a.a和b.b的输出值是多少? #include <iostream> struct foo { foo() = default; int a; ...

  2. 2016.6.17——Remove Duplicates from Sorted Array

    Remove Duplicates from Sorted Array 本题收获: 1.“删除”数组中元素 2.数组输出 题目: Given a sorted array, remove the du ...

  3. java连接redis无法连接,报异常RedisConnectionException

    不管是spring还是原生jedis连接redis,如果连不上多半是linux服务器的问题: 1 首先确保redis端口开放: 把6379或者redis的端口开放即可 2 redis.conf配置注释 ...

  4. layui table表格字段过长,展示不完整时,鼠标放到上面展示完整信息

    亲测可以直接用 1.首先每个列都有一个title,里面放入完整信息,然后写一个如下的function, function tdTitle(){ $('th').each(function(index, ...

  5. linux arm mmu基础【转】

    转自:http://blog.csdn.net/xiaojsj111/article/details/11065717 ARM MMU页表框架 先上一张arm mmu的页表结构的通用框图(以下的论述都 ...

  6. Southwestern Europe Regional Contest 2015 题解

    题目链接:http://codeforces.com/gym/101128 题目数7/10 Rank 34/209 A: 题意:给出一张n个点的有向图表示一家有n个员工的公司的隶属图,u->v表 ...

  7. 线性表应用--Josephus问题的解法(Python 版)

    线性表应用 --Josephus问题的解法(Python 版) Josephus问题描述:假设有n个人围坐一圈,现在要求从第k个人开始报数,报到第m个数的人退出.然后从下一个人开始继续报数并按照相同的 ...

  8. Shell编程学习1--基础了解

    "#!path"告诉系统path所指的程序为用来解释此脚本文件的Shell程序: 如#!/bin/sh, #!/bin/bash Shell Script的后缀名为.sh; ech ...

  9. 洛谷P1195口袋的天空

    传送门啦 一个裸的最小生成树,输出 $ No Answer $ 的情况只有 $ k < n $ 的时候. 开始令 $ num =n $ ,如果 $ num = k $ ,直接输出 $ 0 $ , ...

  10. (四)Jsoup 获取 DOM 元素属性值

    第一节: Jsoup 获取 DOM 元素属性值 Jsoup获取DOM元素属性值 比如我们要获取博客的href属性值: 我们这时候就要用到Jsoup来获取属性的值 : 我们给下示例代码: package ...