如有错误,烦请各位指出🙂🙂🙂
Lucas 组合数取模
b存在乘法逆元的充要条件是b与模数m互质
def exgcd(a, b): #扩展欧几里得
if b == 0:
x = 1
y = 0
return x, y
x1, y1 = exgcd(b, a % b)
x = y1
y = x1 - (a // b) * y1
return x, y
'''
费马小定理,若p为素数
a ^ p % p = 1
所以当p为素数时
b的逆元为 b ^ (p - 2)
b存在乘法逆元的充要条件是b与模数m互质
'''
def quick_mod(a, b, p): #快速幂
# return a^b%p
ans = 1
a %= p
while b:
if b & 1:
ans = ans * a % p
b -= 1
b >>= 1
a = a * a % p
return ans
def Inv(b, p): #求逆元
x, y = exgcd(b, p)
return (x + p) % p
def C(n, m, p):
if m > n: return 0
a = 1; b = 1
while m:
a = a * n % p
n -= 1
b = b * m % p
m -= 1
return a * Inv(b, p) % p
def Lucas(n, m, p):
if m == 0:
return 1
return C(n % p, m % p, p) * Lucas(n // p, m // p, p) % p
素数判定
def judge(x):
if x < 2: return False
sqx = int(math.sqrt(x)) + 1
for i in range(2, sqx):
if x % i == 0: return False
return True
质因数分解
def prime_fac(x):
p = []
c = []
for i in range(2, int(sqrt(x)) + 1):
if x % i == 0:
p.append(i)
cnt = 0
while x % i == 0:
x //= i
cnt += 1
if cnt: c.append(cnt)
if x > 1:
p.append(x)
c.append(1)
return p, c
最大公约数
python自带gcd函数哦
import math
print(math.gcd(4, 6))
快速幂
def quick_mod(a, b, p):
'''
return a ^ b mod p
'''
ans = 1
while b:
if b & 1: ans *= a
a = a * a % p
b >>= 1
return ans % p
pow(a, b, c)
#这个是内置函数,直接就是快速幂,比我上面手写那个要快一些
扩展欧几里得
通解:
$a’ = a // gcd(a, b)$
$b’ = b // gcd(a, b)$
$x = x’ + k * b’$
$y = y’ - k * a’$
最小正整数解
$x = x’ mod b’$
def ex_gcd(a, b):
'''
return ax + by = gcd(a, b)
'''
if b == 0:
x = 1
y = 0
return x, y
x1, y1 = ex_gcd(b, a % b)
x = y1
y = x1 - (a // b) * y1
return x, y
质数筛
#线性筛
'''
if i % primes[j] == 0: break
我们希望每个合数被最小质因子筛除
break的原因是此时pj是i的最小质因子,那么下一个pj*i筛的合数的最小质因子一定不是pj
'''
cnt = 0 #cnt表示质数总个数
for i in range(2, n+1):
if not vis[i]: #vis这个列表用来标记一个数是否被筛选过
cnt += 1
primes[cnt] = i #primes列表用来记录每一个质数
for j in range(1, cnt+1):
if primes[j] > n//i: break # 原因请见最上方注释
vis[primes[j] * i] = 1
if i % primes[j] == 0: break
质因数分解
'''
可能存在大于sqrt(x)的质因子
最后x如果不为1就说明此时的x为大于sqrt(x)的质因子
'''
import math
def get_prime_fac(x):
sqr_x = int(math.sqrt(x))+ 1
for i in range(2, sqr_x):
cnt = 0
if x % i == 0:
while x % i == 0: x //= i; cnt +=1
print(i, cnt) #i是当前质因数,cnt是指数
if x != 1:
print(x, 1) #x表示质因数,1表示指数是1
print() # 输出一个回车,无实际意义
#1
手写快速幂和python自带快速幂用起来有什么区别吗
以我目前的认识,应该是没有区别的,不放心的话可以手写一下,也不是很长
太强了
啊,您过奖了,大佬,我就是写一下当作复习用,有错误的话,劳烦您指出哦
只有很少一部分哈,各位见谅,后续会补充