Acwing151周赛T2序列数量,组合计数

本文讨论了解决关于正整数和非负整数序列的组合问题,通过将不等式转化为等式并应用隔板法和逆元理论,计算C(n+m)^m的值,同时考虑了特殊情况如质数模数和加1变换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

方程的正整数解问题

x1 + x2 + x3 ... + xn = m
其中 xi为正整数,问:有多少种组合
此时利用隔板法。
==> m个小球,分给n个人,每个人至少一个。
==> m个小球,m - 1的空隙,放置n -1个隔板即可
C m − 1 n − 1 C_{m-1}^{n-1} Cm1n1

逆元问题

若整数 b,m 互质,并且对于任意的整数 a,如果满足 b|a (b能被a整除),则存在一个整数 x,使得 a b \frac{a}{b} ba a × x ( m o d m ) a \times x(mod m) a×x(modm),则称 x 为 b 的模 m 乘法逆元,记为 b−1(mod m)。
b 存在乘法逆元的充要条件是 b 与模数 m 互质。当模数 m 为质数时,bm−2 即为 b 的乘法逆元。
普通话解释:如果要求 a b \frac{a}{b} ba % m 的结果,可以用a 乘上逆元,即 a * bm-2 % m, m必须为质数

给定整数 n,m ,
请你计算,一共有多少个长度为 m的非负整数序列 a1,a2,…,am 满足 1≤a1+a2+…+am≤n 由于结果可能很大,你只需要输出对 106+3 取模后的结果。

我们只会方程,即等式,这题是不等式。所以需要转换一下。
由于是非负整数所有每个数的范围是0 <= ai <=n.
现在新添加一个数 a(m+1) 用来填充 a1+a2+…+am 的结果。
a(m+1) 的范围是 0 <= a(m+1) <= n -1 ,但是此时a(m+1) 变得跟其他不一样了,为了让a(m+1) 的范围跟其他也一样,需要先扩大a(m+1) 的范围,然后再减去多算的那些0<=a(m+1) <=n,当a(m+1) =n时,此时属于多算了,此时的序列只有一种即a0 = 0, a1 = 0 … an = 0, a(m+1) = n

此时还不满足我们的知识,因为此时的a还不是正整数,我们在每个ai的基础上 + 1 变成bi
此时就变成了
b1 + … + bm+1 = n + m + 1有多少正整数解的问题了
C n + m m C_{n + m}^{m} Cn+mm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值