两个互质数的线性组合=1一定有解。spa
即ax + by = 1 (a、b互质, a > b)。io
当x=1,y 的值等于某个数时,ax+by的值为 a%b, 设这个数为zgc
·若a%b = 1, 原表达式成立;经验
·若a%b != 1, 则 a + bz = a%b,因而 x *(a + bz) = x * (a%b)(ax+by能够表示成a%b的线性组合)co
既然ax + by 能够表示成(a%b)的线性组合 , 则 ax + by 能够表示成 a 和 (a%b) 的线性组合 或 b 和 (a%b)的线性组合 或 a、b 和 (a%b)的线性组合。gcd
(经验告诉咱们,选第二个啦)
此时问题转化为了b和(a%b)的线性组合 = 1是否有解, 即 bx + (a%b)* y = 1 是否有解,
不停转换下去,由于gcd(a,b) == 1, 最终b 必定 为 1, a%b 必定等于0, 因而此表达式必定有解。
而后裴蜀定理(ax + by = gcd(a,b)必定有解)也就这样被证实了(?!)。
推论:{
(1):
互质数的最小公倍数是这两个数之积,即 lcm(a,b) = a*b。
解释, 因为 a、b互质, 则 ax + by = 1 一定有解, 设两个数的一个公倍数是N,
则 a|N 且 b|N, 因而 (a*b)| (N*b)且(a*b)|(N*a), 因而(a*b)|(x*(N*b)+y*(N*a)),
即(a*b)|(N*(ax + by)), 而ax + by 的最小值(非零)为1, 因而(a*b)|N,这意味着
a、b的公倍数是(a*b)的倍数, (a*b)的最小倍数(非零)是 1, 则a、b的最小公倍数是 a*b。
}