1006C简单题(计数式子的组合意义 + dp式子联立)

http://cplusoj.com/d/senior/p/SS241006C

在这里插入图片描述

对于这个式子,我们可以从它的组合意义入手。

假设我们有 n + 1 n+1 n+1 个白球要染色,中间有一个绿球,绿球左边有 a a a 个红球,右边有 b b b 球。染完后绿球左边每个白球有 x x x 的贡献,右边每个白球有 y y y 的贡献。

但接下来怎么做呢?这列出来的式子不是一样吗?注意,当我们转化为组合意义的时候,我们就可以不考虑计数的方法了,我们可以用dp了。

d p ( n , a , b ) dp(n,a,b) dp(n,a,b) 表示当前的答案。保证绿球一定存在。

转移的话,我们可以考虑最左边和最右边的球的颜色:

d p ( n , a , b ) = d p ( n − 1 , a − 1 , b ) + x d p ( n − 1 , a , b ) dp(n,a,b)=dp(n-1,a-1,b)+xdp(n-1,a,b) dp(n,a,b)=dp(n1,a1,b)+xdp(n1,a,b)
d p ( n , a , b ) = d p ( n − 1 , a , b − 1 ) + y d p ( n − 1 , a , b ) dp(n,a,b)=dp(n-1,a,b-1)+ydp(n-1,a,b) dp(n,a,b)=dp(n1,a,b1)+ydp(n1,a,b)

考虑边界条件 a = 0 a=0 a=0,或 b = 0 b=0 b=0

  • a = 0 a=0 a=0 d p ( n , 0 , b ) = x d p ( n − 1 , 0 , b ) + ( n − 1 b ) y n − b − 1 dp(n,0,b)=xdp(n-1,0,b)+\binom{n-1}{b}y^{n-b-1} dp(n,0,b)=xdp(n1,0,b)+(bn1)ynb1
  • b = 0 b=0 b=0 d p ( n , a , 0 ) = y d p ( n − 1 , a , 0 ) + ( i − 1 a ) x i − a − 1 dp(n,a,0)=ydp(n-1,a,0)+\binom{i-1}{a}x^{i-a-1} dp(n,a,0)=ydp(n1,a,0)+(ai1)xia1

然后就到了这题最巧妙的地方了。我们发现 n n n 很大,但是是定值。而 a , b a,b a,b 很小,这启示我们并不是往矩阵来想,而是我们考虑把 n n n 丢掉。

我们直接联立最前面两条式子:

d p ( n − 1 , a − 1 , b ) + x d p ( n − 1 , a , b ) = d p ( n − 1 , a , b − 1 ) + y d p ( n − 1 , a , b ) ( x − y ) d p ( n − 1 , a , b ) = d p ( n − 1 , a , b − 1 ) − d p ( n − 1 , a − 1 , b ) dp(n-1,a-1,b)+xdp(n-1,a,b)=dp(n-1,a,b-1)+ydp(n-1,a,b)\\ (x-y)dp(n-1,a,b)=dp(n-1,a,b-1)-dp(n-1,a-1,b) dp(n1,a1,b)+xdp(n1,a,b)=dp(n1,a,b1)+ydp(n1,a,b)(xy)dp(n1,a,b)=dp(n1,a,b1)dp(n1,a1,b)

d p ( n − 1 , a , b ) = d p ( n − 1 , a , b − 1 ) − d p ( n − 1 , a − 1 , b ) x − y dp(n-1,a,b)=\dfrac{dp(n-1,a,b-1)-dp(n-1,a-1,b)}{x-y} dp(n1,a,b)=xydp(n1,a,b1)dp(n1,a1,b)

这时就可以把 n n n 丢掉了。

对于边界条件的处理,我们照样联立即可。

联立 a = 0 a=0 a=0 b = 0 b=0 b=0,可以解出 d p ( 0 , 0 ) dp(0,0) dp(0,0) 时的答案

联立 a = 0 a=0 a=0 b ≠ 0 b\neq 0 b=0,可以解出 d p ( 0 , b ) dp(0,b) dp(0,b) 的答案。

然后就做完了

现在我们还有最后一个问题, x = y x=y x=y 怎么处理。

我们直接回归原式,然后把 x n − a − b x^{n-a-b} xnab 提到外面,再重新剩下那坨式子的组合意义,此时红色蓝色已经没有意义了,相当于就是 n + 1 n+1 n+1 个球选 a + b + 1 a+b+1 a+b+1 个球,即为 ( n + m + 1 a + b + 1 ) \binom{n+m+1}{a+b+1} (a+b+1n+m+1)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值