ABC266 G(二项式反演)

题目链接

  题目大意:有aR, bG, cB,要求出来恰好有k个连续的RG的排列方案数。
  思路:
    可以先将问题转化成至少有kRG的排列方案数有多少,然后可以用二项式反演的方法,将所有cntRG=k的方案数加起来就好了。二项式反演有这样的式子F(n)=(ni)D(i)D(n)=(1)ni(ni)F(i),那么我们将D(n)求出来就好了。

int r, g, b, k; std::cin >> r >> g >> b >> k; int n = r + g + b; fac[0] = fav[0] = 1; for (int i = 1; i <= n; i++) fac[i] = 1LL * fac[i - 1] * i % mod; fav[n] = power(fac[n], mod - 2); for (int i = n - 1; i >= 1; i--) fav[i] = 1LL * fav[i + 1] * (i + 1) % mod; auto C = [&](int n, int m) -> int { if (m > n || m < 0) return 0; return 1ll * fac[n] * fav[m] % mod * fav[n - m] % mod; }; std::vector<int> f(n + 1); for (int i = 0; i <= std::min(r, g); i++) { int x = r - i, y = g - i; int m = x + y + i + b; f[i] = 1ll * C(m, i) * C(m - i, x) % mod * C(m - x - i, y) % mod * C(m - x - i - y, b) % mod; } int ans = 0; for (int i = k; i <= std::min(r, g); i++) { int p = ((i - k) & 1) ? -1 : 1; ans = (1ll * ans + mod + 1ll * p * C(i, k) % mod * f[i] % mod) % mod; } std::cout << ans << "\n";

__EOF__

本文作者HoneyGrey
本文链接https://www.cnblogs.com/Haven-/p/16660835.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   浅渊  阅读(62)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示