【数学】整除

开数论坑了TAT

本文介绍整除、最小公倍数、最大公约数和扩展欧几里得算法等基础知识。

退役边缘人,近期整理下模板啦~

基本概念与性质

  • 偶数、奇数
  • mod:a=qb+r,0r<b0\mod: a=qb+r,0\leq r<|b|\neq 0,记作r=amodbr=a\mod b
  • ab,acx,y,abx+cya|b,a|c\Rightarrow \forall x,y,a|bx+cyaa 称公因子,最大的记作gcd(a,b)\gcd(a,b)(对应有最小公倍数lcm(a,b)lcm(a,b))。
  • ab,bcaca|b,b|c\Rightarrow a|c
  • m0,abmambm\neq 0,a|b\Leftrightarrow ma|mb
  • ab,baa=±ba|b,b|a\Rightarrow a=\pm b
  • ab,b0aba|b,b\neq 0\Rightarrow |a|\leq |b|
  • am,bmlcm(a,b)m;da,dbdgcd(a,b)a|m,b|m\Rightarrow lcm(a,b)|m;d|a,d|b\Rightarrow d|\gcd(a,b)
  • ab=gcd(a,b)×lcm(a,b)ab=\gcd(a,b)\times \text{lcm}(a,b)
  • m,a,bN+,lcm(ma,mb)=m×gcd(a,b)m,a,b\in N^+,\text{lcm}(ma,mb)=m\times \gcd(a,b)

辗转相除法(欧几里得算法)

a=qb+r,0r<b0,gcd(a,b)=gcd(b,r)a=qb+r,0\leq r<|b|\neq 0,\gcd(a,b)=\gcd(b,r)

1
ll gcd(ll a, ll b) { return b == 0 ? a : gcd(b, a % b); }

扩展欧几里得

gcd(a,b)=xa+yb\gcd(a,b)=xa+yb ,求解x,yx,y

推论:gcd(a,b)=1a,b互素存在xa+by=1\gcd(a,b)=1\Leftrightarrow a,b互素\Leftrightarrow 存在xa+by=1

算法计算次数:拉梅定理(咕咕咕)

1
2
3
4
5
6
7
8
9
10
11
// 扩展欧几里得:ax+by=gcd(a,b)=d
void exgcd(ll a, ll b, ll &d, ll &x, ll &y)
{
if (!b)
{
x = 1, y = 0, d = a;
return;
}
exgcd(b, a % b, d, y, x);
y -= a / b * x;
}