方程的正整数解问题
x1 + x2 + x3 ... + xn = m
其中 xi
为正整数,问:有多少种组合
此时利用隔板法。
==> m
个小球,分给n
个人,每个人至少一个。
==> m
个小球,m - 1
的空隙,放置n -1
个隔板即可
⇒
C
m
−
1
n
−
1
C_{m-1}^{n-1}
Cm−1n−1
逆元问题
若整数 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