White and Black Balls

题目大意

将 \(n\) 个白球,\(m\) 个黑球排成一列,要求满足 \(\forall i\in[1,n+m],w_i\le b_i+k\),问存在多少种排法。

其中 \(w_i\) 表示第 \(i\) 个球前的白球数量,\(b_i\) 表示第 \(i\) 个球前的黑球数量。

思路分析

我们可以将一种排法映射成一条从 \((0,0)\) 到 \((m,n)\) 的路径。具体的说,从 \((0,0)\) 开始,如果当前球是白球,那么向上移动一个单位长度;如果是黑球,那么向右移动一个单位长度,到达 \((m,n)\) 结束。

容易发现,路径条数为 \(C_{n+m}^m\),但其中包含不合法的情况,需要排除。

如图,我们发现,如果一条路径始终位于直线 \(y=x+k\) 下方,那么这条路径就是合法的。换而言之,如果一条路径与直线 \(y=x+k+1\) 有交点,那么这条路径不合法。

对于不合法的路径,我们将最右端的交点的左半部分沿 \(y=x+k+1\) 翻转,得到一条新的从 \((-k-1,k+1)\) 到 \((m,n)\) 的路径,显然所有的不合法路径可以通过这种办法与从 \((-k-1,k+1)\) 到 \((m,n)\) 的路径一一对应。而这样的路径条数为 \(C_{n+m}^{m+k+1}\)。

因此,最后的答案就是 \(C_{n+m}^m-C_{n+m}^{m+k+1}\)。

注意特判 \(n>m+k\) 的情况。

代码

  1. #include <iostream>
  2. #include <cmath>
  3. #include <cstring>
  4. #include <algorithm>
  5. #include <cstdio>
  6. using namespace std;
  7. const int N=2000100,L=2000000,mod=1000000007;
  8. #define int long long
  9. int n,m,k;
  10. int fac[N],inv[N];
  11. int q_pow(int a,int b){
  12. int res=1;
  13. while(b){
  14. if(b&1) res=(res*a)%mod;
  15. a=(a*a)%mod;
  16. b>>=1;
  17. }
  18. return res;
  19. }
  20. int C(int a,int b){//逆元法直接计算
  21. return ((fac[a]*inv[b]%mod)*inv[a-b])%mod;
  22. }
  23. signed main(){
  24. scanf("%lld%lld%lld",&n,&m,&k);
  25. fac[0]=1;
  26. for(int i=1;i<=L;i++) fac[i]=fac[i-1]*i%mod;
  27. inv[L]=q_pow(fac[L],mod-2);
  28. for(int i=L;i>=1;i--) inv[i-1]=inv[i]*i%mod;//预处理逆元
  29. if(n>m+k){cout<<"0\n";return 0;}//特判
  30. int ans=(C(n+m,m)-C(n+m,m+k+1)+mod)%mod;//计算答案,可能出负数,需再模一遍
  31. cout<<ans<<'\n';
  32. return 0;
  33. }

[ABC205E] White and Black Balls 题解的更多相关文章

  1. CF755G PolandBall and Many Other Balls 题解

    从神 Karry 的题单过来的,然后自己瞎 yy 了一个方法,看题解区里没有,便来写一个题解 一个常数和复杂度都很大的题解 令 \(dp_{i,j}\) 为 在 \(i\) 个球中选 \(j\) 组的 ...

  2. [POJ3783]Balls 题解

    题目大意 鹰蛋问题.$ n\(个蛋,\)m\(层楼. 存在一层楼\)E\(,使得\)E\(以及\)E\(以下的楼层鹰蛋都不会摔碎,问最坏情况下最少多少次能够知道\)E$. 非常经典的模型,初看题目根本 ...

  3. CF850F Rainbow Balls 题解

    考虑最后变成哪一种颜色. 设 \(s = \sum\limits_{i=1}^n a_i\) 设现在有 \(k\) 种当前颜色, 需要全部变成该种颜色, 期望步数为 \(f_k\). 考虑状态转移.设 ...

  4. Codeforces Round #368 (Div. 2)A B C 水 图 数学

    A. Brain's Photos time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  5. [HackerRank]Choosing White Balls

    [HackerRank]Choosing White Balls 题目大意: 有\(n(n\le30)\)个球排成一行,每个球的颜色为黑或白. 执行\(k\)次操作,第\(i\)次操作形式如下: 从\ ...

  6. 题解-CF755G PolandBall and Many Other Balls

    题面 CF755G PolandBall and Many Other Balls 给定 \(n\) 和 \(m\).有一排 \(n\) 个球,求对于每个 \(1\le k\le m\),选出 \(k ...

  7. HDU 3911 Black And White 分段树 题解

    Problem Description There are a bunch of stones on the beach; Stone color is white or black. Little ...

  8. POJ 3687 Labeling Balls(拓扑排序)题解

    Description Windy has N balls of distinct weights from 1 unit to N units. Now he tries to label them ...

  9. HDU1510 White rectangles( 乱搞 O(n^3) )题解

    思路: 友谊赛的时候一直想到了,但是没想出来怎么遍历才能找到所有矩阵,卡住了. 这里讲一下完整思路:我们用一个num[i][j]表示第i行第j列每一列连续的白色格子数量,然后我们定义一个MIN,并且每 ...

  10. 【题解】Popping Balls AtCoder Code Festival 2017 qual B E 组合计数

    蒟蒻__stdcall终于更新博客辣~ 一下午+一晚上=一道计数题QAQ 为什么计数题都这么玄学啊QAQ Prelude 题目链接:这里是传送门= ̄ω ̄= 下面我将分几个步骤讲一下这个题的做法,大家不 ...

随机推荐

  1. 即构SDK支持对焦、变焦、曝光调整,让直播细节清晰呈现

    对焦.变焦.曝光调整,摄影爱好者对这三个术语一定不陌生. 对焦是指通过相机对焦机构变动物距和相距的位置,使被拍物成像清晰的过程:变焦指的是在望远拍摄时放大远方物体,并使之清晰成像 :曝光调整是一种曝光 ...

  2. stegsolve与zsteg的使用

    zsteg 介绍:用来检测PNG和BMP中隐藏数据的工具,可以快速提取隐藏信息 使用环境:kali kali自带zsteg,可以用这个指令使用 gem install zsteg 下载完之后查看使用方 ...

  3. PlayWright(二十一)- Pytest插件报告

    1.下载 pytest框架有官方的报告pip install pytest-html   下载成功,那我们怎么使用呢?   2.使用 可以直接在配置文件里使用   在 pytest 配置文件中, 增加 ...

  4. debian 防火墙命令 nft

    参考链接:nftables # which nft /usr/sbin/nft # dpkg -S /usr/sbin/nft nftables: /usr/sbin/nft # dpkg -L nf ...

  5. 2021-3-13 xml的增删改查

    public void XmlAdd(string filename, List<People> pList) { try { List<People> peoples = X ...

  6. 《HelloGitHub》第 88 期

    兴趣是最好的老师,HelloGitHub 让你对编程感兴趣! 简介 HelloGitHub 分享 GitHub 上有趣.入门级的开源项目. https://github.com/521xueweiha ...

  7. React:TypeError: Cannot read properties of undefined (reading 'map')

    解决方案 js中?问号代表可选项 可选链式操作符 参考链接 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Oper ...

  8. 关于Linux下服务器MySQL的安装和搭建

    一.检测是否已经安装Mysql 检测 # yum list installed | grep mysql //检查安装 # yum -y remove mysql-libs.x86_64 //卸载 / ...

  9. JMeter 线程组之Stepping Thread Group插件

    JMeter 线程组之Stepping Thread Group插件 测试环境   apache-jmeter-2.13 插件:https://jmeter-plugins.org/downloads ...

  10. ctfshow--web入门--文件上传

    ctfshow--web入门--文件上传 web151(前端校验) 题目中提示前端检验不可靠,应该对前端检验进行绕过 检查前端代码进行修改,使php文件可以通过前端校验,成功上传后进行命令执行,找到f ...