CF451E Devu and Flowers

题意:

\(Devu\)有\(N\)个盒子,第\(i\)个盒子中有\(c_i\)枝花。同一个盒子内的花颜色相同,不同盒子的花颜色不同。\(Devu\)要从中选出\(M\)枝花,求有多少种方案,对\(10e9+7\)取模。

数据范围

\(1 \le N \le 20,0 \le M \le 10^{14},0 \le c_i \le 10^{12}\)


其实就是求多重集组合数的模板题。

可以看看我写的博客

一些注意点,发现直接求会爆\(long long\),\(lucas\)一下免得爆了

注意\(M\)很大\(N\)很小,所以先把\((M-N)!\)除掉再算复杂度就是对的了


Code:

  1. #include <cstdio>
  2. #define ll long long
  3. const ll mod=1e9+7;
  4. ll quickpow(ll d,ll k)
  5. {
  6. ll f=1;
  7. while(k)
  8. {
  9. if(k&1) f=f*d%mod;
  10. d=d*d%mod;
  11. k>>=1;
  12. }
  13. return f;
  14. }
  15. ll cal(ll r,ll l)
  16. {
  17. ll s=1;
  18. for(ll i=r;i>l;i--) (s*=i)%=mod;
  19. return s;
  20. }
  21. ll inv[22];
  22. ll C(ll m,ll n)
  23. {
  24. if(m<n) return 0;
  25. if(n==0) return 1;
  26. if(m<mod) return cal(m,m-n)*inv[n]%mod;
  27. return C(m/mod,n/mod)*C(m%mod,n%mod)%mod;
  28. }
  29. ll n,s,f[23];
  30. int main()
  31. {
  32. scanf("%lld%lld",&n,&s);
  33. ll fac=1;
  34. for(ll i=1;i<=n;i++)
  35. {
  36. fac=fac*i%mod;
  37. inv[i]=quickpow(fac,mod-2);
  38. scanf("%lld",f+i);
  39. }
  40. ll ans=0;
  41. for(int i=0;i<1<<n;i++)
  42. {
  43. ll m=s+n-1,cnt=0;
  44. for(int j=0;j<n;j++)
  45. if(i>>j&1)
  46. m-=f[j+1],cnt++;
  47. (ans+=(cnt&1?-1ll:1ll)*C(m-cnt,n-1))%=mod;
  48. }
  49. printf("%lld\n",(ans%mod+mod)%mod);
  50. return 0;
  51. }

2018.10,17

CF451E Devu and Flowers 解题报告的更多相关文章

  1. Luogu CF451E Devu and Flowers 题解报告

    题目传送门 [题目大意] 有n种颜色的花,第i种颜色的花有a[i]朵,从这些花中选m朵出来,问有多少种方案?答案对109+7取模 [思路分析] 这是一个多重集的组合数问题,答案就是:$$C_{n+m- ...

  2. CF451E Devu and Flowers(容斥)

    CF451E Devu and Flowers(容斥) 题目大意 \(n\)种花每种\(f_i\)个,求选出\(s\)朵花的方案.不一定每种花都要选到. \(n\le 20\) 解法 利用可重组合的公 ...

  3. CF451E Devu and Flowers (隔板法 容斥原理 Lucas定理 求逆元)

    Codeforces Round #258 (Div. 2) Devu and Flowers E. Devu and Flowers time limit per test 4 seconds me ...

  4. CF451E Devu and Flowers 数论

    正解:容斥+Lucas定理+组合数学 解题报告: 传送门! 先mk个我不会的母函数的做法,,, 首先这个题的母函数是不难想到的,,,就$\left (  1+x_{1}^{1}+x_{1}^{2}+. ...

  5. BZOJ1101 [POI2007]Zap 和 CF451E Devu and Flowers

    Zap FGD正在破解一段密码,他需要回答很多类似的问题:对于给定的整数a,b和d,有多少正整数对x,y,满足x<=a,y<=b,并且gcd(x,y)=d.作为FGD的同学,FGD希望得到 ...

  6. 【LeetCode】605. Can Place Flowers 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 解题方法 贪婪算法 日期 题目地址:https://leetcode.c ...

  7. sgu 104 Little shop of flowers 解题报告及测试数据

    104. Little shop of flowers time limit per test: 0.25 sec. memory limit per test: 4096 KB 问题: 你想要将你的 ...

  8. CF451E Devu and Flowers(组合数)

    题目描述 Devu想用花去装饰他的花园,他已经购买了n个箱子,第i个箱子有fi朵花,在同一个的箱子里的所有花是同种颜色的(所以它们没有任何其他特征).另外,不存在两个箱子中的花是相同颜色的. 现在De ...

  9. codeforces 459 B.Pashmak and Flowers 解题报告

    题目链接:http://codeforces.com/problemset/problem/459/B 题目意思:有 n 朵 flowers,每朵flower有相应的 beauty,求出最大的beau ...

随机推荐

  1. php如何将base64数据流文件转换为图片文件?

    2017-03-07 在开发中,自己遇到一个前端在上传图片的时候,使用的base64数据流文件显示的图片. 也就是说 <img src="data:image/jpg;base64,& ...

  2. Hadoop(6)-HDFS的shell操作

    1.基本语法 使用 hadoop fs 具体命令   或者   hdfs dfs 具体命令 hadoop命令的shell源码 hdfs命令的shell源码 由此可见,这两个命令最后都是执行的一个jav ...

  3. keil5 mdk使用ST-Link II下载出现cannot halt the core解决办法

    在正常的程序里面,我添加了MB85RS16(spi flash)这个外设驱动代码后,使用ST-Link II下载就出现cannot halt the core. 这个现象之前出现过1次,但是解决办法忘 ...

  4. LeetCode:15. 3Sum(Medium)

    1. 原题链接 https://leetcode.com/problems/3sum/description/ 2. 题目要求 数组S = nums[n]包含n个整数,请问S中是否存在a,b,c三个整 ...

  5. Hadoop数据倾斜及解决办法

    数据倾斜:就是大量的相同key被partition分配到一个分区里,map /reduce程序执行时,reduce节点大部分执行完毕,但是有一个或者几个reduce节点运行很慢,导致整个程序的处理时间 ...

  6. js数字格式化千分位格式

    带小数点的 var a = 8462948.2453; console.log(a.toLocaleString()) //8,462,948.245 不带小数点的 num.toString().re ...

  7. Android2.2以上的版本HttpURLConnection.getContentLength()获取的size跟下载下来的file的legth不相等

    2.2以上的版本下载网络资源不完整无法更新.HttpURLConnection.getContentLength()获取的size跟下载下来的file的legth不等. 原因是:HttpURLConn ...

  8. C++学习007-使用exit退出进程

    使用exit可以实现退出当前进程. 如下 在程序接收到一个字符后,就退出进程 编写环境 vs2015 int main() { int a = 10, b = 20; std::cout <&l ...

  9. 第一篇 Charles的配置及相关使用

    // Charles Proxy License // 适用于Charles任意版本的注册码,谁还会想要使用破解版呢. // Charles 4.2目前是最新版,可用.   Registered Na ...

  10. Mapper的方式总结

    Mapper的方式总结: <mappers> <!-- 通过package元素将会把指定包下面的所有Mapper接口进行注册 --> <package name=&quo ...