本文实例讲述了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