Python基于递归和非递归算法求两个数最大公约数、最小公倍数示例-创新互联

本文实例讲述了Python基于递归和非递归算法求两个数大公约数、最小公倍数。分享给大家供大家参考,具体如下:

成都创新互联公司专注于璧山企业网站建设,成都响应式网站建设公司,商城网站建设。璧山网站建设公司,为璧山等地区提供建站服务。全流程按需设计网站,专业设计,全程项目跟踪,成都创新互联公司专业和态度为您提供的服务

大公约数和最小公倍数的概念大家都很熟悉了,在这里就不多说了,今天这个是因为做题的时候遇到了所以就写下来作为记录,也希望帮到别人,下面是代码:

#!/usr/bin/env python
#coding:utf-8
from fractions import gcd
#非递归实现
def gcd_test_one(a, b):
  if a!=0 and b!=0:
    if a>b:
      a, b=b, a
    if b%a==0:
      return a
    gcd_list=[]
    for i in range(1,a):
      if b%i==0 and a%i==0:
        gcd_list.append(i)
    return max(gcd_list)
  else:
    print 'Number is wrong!!!'
#递归实现
def gcd_test_two(a, b):
  if a>b:
    a, b=b, a
  if b%a==0:
    return a
  else:
    return gcd_test_two(a,b%a)
#python自带的gcd
def gcd_test_three(a, b):
  return gcd(a,b)
if __name__ == '__main__':
  print gcd_test_one(12,24)
  print gcd_test_one(12,8)
  print gcd_test_one(6,24)
  print gcd_test_one(0,24)
  print '----------------------------------------------------------------------------'
  print gcd_test_two(12,24)
  print gcd_test_two(12,8)
  print gcd_test_two(6,32)
  print '----------------------------------------------------------------------------'
  print gcd_test_three(12,24)
  print gcd_test_three(12,8)


网站名称:Python基于递归和非递归算法求两个数最大公约数、最小公倍数示例-创新互联
分享网址:http://bzwzjz.com/article/jigjj.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 响应式网站设计方案 自适应网站建设 网站建设开发 手机网站制作 成都网站建设 做网站设计 重庆手机网站建设 成都网站设计 手机网站设计 成都响应式网站建设 广安网站设计 成都企业网站建设 成都网站制作 网站建设公司 成都网站建设流程 成都网站设计制作公司 网站建设方案 外贸网站设计方案 专业网站建设 重庆网站制作 成都网站建设 成都网站建设公司