鱼C论坛

 找回密码
 立即注册
查看: 1130|回复: 2

[已解决]22讲,课后题2,显示不能除以0,是什么情况

[复制链接]
发表于 2020-3-22 22:45:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#使用递归编写一个函数,利用欧几里得算法求最大公约数
#,例如 gcd(x, y) 返回值为参数 x 和参数 y 的最大公约数。
def gcd(bigger,littler):
    time=0
    yu_shu=1                    #任意给一个不为0的初值
    while yu_shu!=0 :
             yu_shu=bigger%littler
             time+=1
             if time>=5:        #如果计算次数超过5,默认为不存在公约数,结束循环
                 return -1
                 break   
             return gcd(littler,yu_shu)
    return littler
        


number1=int(input("enter an interger,bigger:"))
number2=int(input("enter an interger,littler:"))
if number1<number2:
    print("wrong enter")
else:
    result=gcd(number1,number2)
    if result==-1:
        prinnt("not exist")
    else:
        print("result=",result)
最佳答案
2020-3-22 23:22:57
这个错误是因为递归的最深层次的时候,bigger是最大公约数,littler是0,再次进入递归后就会出现除数为0的情况。
你的程序问题不少。
while循环没意义,因为在循环内会有return语句,不会真正的循环的,直接用if语句就可以了,而且条件也不对,应该是littler!=0
你所认为的time完全没有作用,你想和递归五次就不再计算,但是你的程序中time每次递归都赋值为0,time不会大于1的。
最深层次的递归,bigger是最大公约,littler是0,应该返回bigger,而不是littler
没必要判断两个输入的大小,若大小相反的话,也就多算一次而已。
def gcd(bigger,littler):
    time=0
    yu_shu=1                    #任意给一个不为0的初值 
    if littler!=0 :          #应该用if,判断条件不应该是yu_shu,而应该是littler
        yu_shu=bigger%littler
        time+=1
        print('time=',time)
        if time>=5:        #如果计算次数超过5,默认为不存在公约数,结束循环
            return -1   
        return gcd(littler,yu_shu)
    return bigger

number1=int(input("enter an interger,bigger:"))
number2=int(input("enter an interger,littler:"))
print(gcd(number1,number2))     #不用判断大小,大小搞反的话,也就多算一次而已

去掉time计数,不设置递归次数的程序如下:
def gcd(bigger,littler):
    if littler!=0:
        return gcd(littler,bigger%littler)
    return bigger

number1=int(input("enter an interger,bigger:"))
number2=int(input("enter an interger,littler:"))
print("%d和%d的最大公约数是%d"%(number1,number2,gcd(number1,number2)))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-3-22 23:22:57 | 显示全部楼层    本楼为最佳答案   
这个错误是因为递归的最深层次的时候,bigger是最大公约数,littler是0,再次进入递归后就会出现除数为0的情况。
你的程序问题不少。
while循环没意义,因为在循环内会有return语句,不会真正的循环的,直接用if语句就可以了,而且条件也不对,应该是littler!=0
你所认为的time完全没有作用,你想和递归五次就不再计算,但是你的程序中time每次递归都赋值为0,time不会大于1的。
最深层次的递归,bigger是最大公约,littler是0,应该返回bigger,而不是littler
没必要判断两个输入的大小,若大小相反的话,也就多算一次而已。
def gcd(bigger,littler):
    time=0
    yu_shu=1                    #任意给一个不为0的初值 
    if littler!=0 :          #应该用if,判断条件不应该是yu_shu,而应该是littler
        yu_shu=bigger%littler
        time+=1
        print('time=',time)
        if time>=5:        #如果计算次数超过5,默认为不存在公约数,结束循环
            return -1   
        return gcd(littler,yu_shu)
    return bigger

number1=int(input("enter an interger,bigger:"))
number2=int(input("enter an interger,littler:"))
print(gcd(number1,number2))     #不用判断大小,大小搞反的话,也就多算一次而已

去掉time计数,不设置递归次数的程序如下:
def gcd(bigger,littler):
    if littler!=0:
        return gcd(littler,bigger%littler)
    return bigger

number1=int(input("enter an interger,bigger:"))
number2=int(input("enter an interger,littler:"))
print("%d和%d的最大公约数是%d"%(number1,number2,gcd(number1,number2)))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-23 09:49:17 | 显示全部楼层
sunrise085 发表于 2020-3-22 23:22
这个错误是因为递归的最深层次的时候,bigger是最大公约数,littler是0,再次进入递归后就会出现除数为0的 ...

蟹蟹
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-25 07:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表