当前位置: 首页 > news >正文

214. Devu和鲜花

214. Devu和鲜花 - AcWing题库

a_{1}+a_{2}+a_{3}+...+a_n = m

如果每个盒子里的花的数量是无限的,用隔板法可以得出答案是 C_{n + m - 1}^{n - 1}

现在每个盒子中区的花数要满足n个条件a_i<=A_i

我们可以求答案的补集,用全部方案数减去补集方案数

每一个不符合条件的要求为a_i>A_i,设为Bi

补集方案数为\sum B_i-\sum (B_i\bigcap B_j ) + ...就成了一个容斥原理

对于一个不符合要求的是C_{n+m-1-(a_i+1)}^{n-1},这就相当于先把ai+1个减了再用隔板法

多个以此类推

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'using namespace std;typedef pair<int, int> PII;
typedef long long ll;
typedef long double ld;const int N = 30, mod = 1e9 + 7;ll n, m;
ll A[N];
int down = 1;int qmi(int a, int k)
{int res = 1;while(k){if(k & 1)res = (ll)res * a % mod;a = (ll)a * a % mod;k >>= 1;}return res;
}int C(ll a, ll b)
{if(a < b)return 0;ll up = 1;for(ll i = a; i > a - b; i --)up = i % mod * up % mod;return up * down % mod;
}int main()
{IOScin >> n >> m;for(int i = 0; i < n; i ++)cin >> A[i];for(int i = 2; i <= n - 1; i ++)down = (ll)down * i % mod;down = qmi(down, mod - 2);int num = 1 << n;ll ans = 0;for(int i = 0; i < num; i ++){ll a = m + n - 1, b = n - 1;int cnt = 0;for(int j = 0; j < n; j ++){if(i >> j & 1){a -= A[j] + 1;cnt ++;}}if(cnt & 1)ans = (ans - C(a, b)) % mod;else ans = (ans + C(a, b)) % mod;}cout << (ans + mod) % mod;return 0;
}

http://www.lryc.cn/news/197396.html

相关文章:

  • 【C++初阶(三)引用与内联函数】
  • RK3288 Android11 mini-pcie接口 4G模组EC200A适配(含自适应功能)
  • Windows安装Jenkins
  • 计算属性,侦听属性,方法区别及例子
  • Windows工业三防平板全功能NFC近距离感应一维/二维扫描
  • git远端协同开发、解决冲突、分支合并、gitlab使用、远程仓库回滚、为开源项目贡献代码、git工作流,git pull和git fetch,变基
  • ims-go项目搭建
  • 2022最新版-李宏毅机器学习深度学习课程-P26 Recurrent Neural Network
  • 【Qt控件之QButtonGroup】概述及使用
  • 【开源分享】基于Html开发的房贷计算器,模仿新浪财经
  • ftp文件上传缓慢问题
  • 【周末闲谈】VR新视界,“眼”见未来
  • CSRF和XSS是什么?
  • 【Machine Learning】01-Supervised learning
  • 《视觉 SLAM 十四讲》V2 第 8 讲 视觉里程计2 【如何根据图像 估计 相机运动】【光流 —> 直接法】
  • Unity DOTS System与SystemGroup概述
  • IDEA使用内置database数据库连接mysql报错:javax.net.ssl.SSLHandshakeException
  • 从Flink的Kafka消费者看算子联合列表状态的使用
  • CSS3 按钮
  • STM32 BootLoader设置
  • django REST framework-使用与不使用的区别?
  • 获取URL中的参数
  • 一起学数据结构(9)——二叉树的链式存储及相关功能实现
  • vue 后端返回二进制流-前端通过blob对象下载文件-图片
  • vue el-dialog封装成子组件(组件化)
  • 爬虫教程 一 requests包的使用
  • Aria2NG连接aria2-pro提示认证失败的处理办法
  • MYSQL 连接
  • SeaTunnel 换maven源,解决插件下载慢
  • 安卓14通过“冻结”缓存应用程序腾出CPU,提高性能和内存效率