Home >Backend Development >Python Tutorial >Example of how to use Python to detect prime numbers
This article mainly introduces the method of Python prime number detection. It analyzes the related skills of Python prime number detection with examples. Friends in need can refer to it. The details are as follows:
## Factor detection:
Detection factor, time complexity O(n^(1/2))def is_prime(n): if n < 2: return False for i in xrange(2, int(n**0.5+1)): if n%i == 0: return False return True
Fermat’s Little Theorem:
If n is a prime number and a is any positive integer less than n, then the nth power of a is congruent with a modulo nImplementation method: Choose a base (for example, 2 ), for a large integer p, if 2^(p-1) and 1 are not congruent modulo p, then p must not be a prime number; otherwise, p is likely to be a prime number2**(n-1)% n is not an easy number to calculate
(a^b) % p = ((a % p)^b) % p (a * b) % p = (a % p * b % p) % pCalculate X^N(% P)Yes
If N is an even number, then X^ N = (X*X)^[N/2];
If N is an odd number, then X^N = X*X^(N-1) = X * (X*X)^[N/2] ;
def xn_mod_p(x, n, p): if n == 0: return 1 res = xn_mod_p((x*x)%p, n>>1, p) if n&1 != 0: res = (res*x)%p return resIt can also be summarized as the following algorithm. The two functions are the same
def xn_mod_p2(x, n, p): res = 1 n_bin = bin(n)[2:] for i in range(0, len(n_bin)): res = res**2 % p if n_bin[i] == '1': res = res * x % p return resWith the fast processing of modular exponentiation operation, Fermat test can be realizedFermat test When a negative conclusion is given, it is accurate, but the positive conclusion may be wrong. It is very efficient for large integers, and the misjudgment rate decreases as the integer increases
def fermat_test_prime(n): if n == 1: return False if n == 2: return True res = xn_mod_p(2, n-1, n) return res == 1
MILLER-RABIN test
Miller-Rabin test is a widely used one at present Quadratic detection theorem: If p is a prime number, and 0Miller test is performed k times , the error probability of treating composite numbers as prime numbers will not exceed 4^(-k) at most
def miller_rabin_witness(a, p): if p == 1: return False if p == 2: return True #p-1 = u*2^t 求解 u, t n = p - 1 t = int(math.floor(math.log(n, 2))) u = 1 while t > 0: u = n / 2**t if n % 2**t == 0 and u % 2 == 1: break t = t - 1 b1 = b2 = xn_mod_p2(a, u, p) for i in range(1, t + 1): b2 = b1**2 % p if b2 == 1 and b1 != 1 and b1 != (p - 1): return False b1 = b2 if b1 != 1: return False return True def prime_test_miller_rabin(p, k): while k > 0: a = randint(1, p - 1) if not miller_rabin_witness(a, p): return False k = k - 1 return True
The above is the detailed content of Example of how to use Python to detect prime numbers. For more information, please follow other related articles on the PHP Chinese website!