本文实例讲述了Python实现的质因式分解算法。分享给大家供大家参考,具体如下:
本来想实现一个其它的基本数学算法问题,但是发现在实现之前必须得先完成分解质因式的算法。
没有去网上寻找什么比较好的求解算法,纯粹是按照自己的理解写了一个试探性求解算法。也就是在MIT公开课中教授提到的guess-try方法。代码实现如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
#!/usr/bin/python
def PrimeNum(num):
r_value = []
for i inrange( 2 ,num + 1 ):
for jin range ( 2 ,i):
ifi % j = = 0 :
break
else :
r_value.append(i)
returnr_value
def PrimeFactorSolve(num,prime_list):
for n inprime_list:
ifnum % n = = 0 :
return [n,num / n]
def PrimeDivisor(num):
prime_range = PrimeNum(num)
ret_vale = []
while numnot in prime_range:
factor_list = PrimeFactorSolve(num,prime_range)
ret_vale.append(factor_list[ 0 ])
num = factor_list[ 1 ]
else :
ret_vale.append(num)
printret_vale
PrimeDivisor( 120 )
|
程序执行结果如下:
E:\WorkSpace\01_编程语言\03_Python\python_exp07>pythonpython_exp07.py
[2, 2, 2, 3, 5]
抽取测试了其他的数据,从简单的例子计算看,结果还是准确的。
希望本文所述对大家Python程序设计有所帮助。
原文链接:https://blog.csdn.net/grey_csdn/article/details/71374514