免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4575 | 回复: 2
打印 上一主题 下一主题

【求教】用递归的方法求素因子 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-12-25 18:35 |只看该作者 |倒序浏览
是在《python核心编程》上看到的一个习题:
素因子分解。以刚才练习中的isprime()和getfactors()函数为基础编写一个函数,它接受一个整型作为参数,返回该整型所有素数因子的列表。这个过程叫做求素因子分解,它输出的所有因子之积应该是原来的数字。注意列表里可能有重复的元素。例如输入20,返回的结果应该是[2,2,5]。


我想到了用递归的方法,但老是出错,请各位大牛帮忙看下哪里出了问题,该怎么纠正。多谢了!
代码如下:
  1. #coding=utf-8

  2. def isprime(num):
  3.     count = num / 2
  4.     while count >1:
  5.         if num % count == 0:
  6.             return False
  7.             break
  8.         else:
  9.             count -= 1
  10.     else:
  11.         return True

  12. def getfactor(num):
  13.     l = []
  14.     count = num / 2
  15.     for n in range(2, count + 1):
  16.         if num % n == 0 and isprime(n):
  17.             l.append(n)
  18.     return l

  19. def suyinzi(num):
  20.     fac = getfactor(num)
  21.     mul = 1
  22.     for n in fac:
  23.         mul *= n
  24.     if mul == num:
  25.         return fac
  26.     else:
  27.         return fac + suyinzi(num / mul)

  28. print suyinzi(20)
复制代码

论坛徽章:
0
2 [报告]
发表于 2012-12-26 12:44 |只看该作者
楼主你的getfactor函数,在循环前要先对num做素性判断,要不然处理不了素数。

  1. def getfactor(num):
  2.     l = []
  3.     if isprime(num):
  4.         return [num]
  5.     count = num / 2
  6.     for n in range(2, count + 1):
  7.         if num % n == 0 and isprime(n):
  8.             l.append(n)
  9.     return l
复制代码
这样就好了

论坛徽章:
0
3 [报告]
发表于 2012-12-26 15:18 |只看该作者
回复 2# river_run


    多谢,确实是这样,之前没考虑明白。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP