鱼C论坛

 找回密码
 立即注册
查看: 2079|回复: 3

[已解决]求帮忙求看一下最大公约数的程序,哪里错了?

[复制链接]
发表于 2017-5-15 22:24:51 | 显示全部楼层 |阅读模式

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

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

x
 def gcd(x,y):
    if x>y:
        a=x
        b=y
    else:
        a=y
        b=x
    t=a//b
    g=a-t*b
    while g!=0:
        r=g
        t=b//r
        g=b-t*r
    return r

>>> gcd(5,2)
1
>>> gcd(30,10)
Traceback (most recent call last):
  File "<pyshell#37>", line 1, in <module>
    gcd(30,10)
  File "<pyshell#35>", line 14, in gcd
    return r
UnboundLocalError: local variable 'r' referenced before assignment

最后需要返回除数,如何才能做到呢?
最佳答案
2017-5-16 00:28:36
本帖最后由 当回首遇上转身 于 2017-5-16 07:59 编辑

首先你这个程序 r 没有赋初值,所以当while g!=0:里面的循环不执行的时候会报“在赋值前引用局部变量'r' ”的错误,
然后其实求最大公约数有更简单的语句。。。
def gcd(a, b):
    while (b > 0):
        a, b = b, a%b
    return a
或者:
def gcd(a, b):
    return gcd(b, a%b) if b > 0 else a
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-5-16 00:28:36 | 显示全部楼层    本楼为最佳答案   
本帖最后由 当回首遇上转身 于 2017-5-16 07:59 编辑

首先你这个程序 r 没有赋初值,所以当while g!=0:里面的循环不执行的时候会报“在赋值前引用局部变量'r' ”的错误,
然后其实求最大公约数有更简单的语句。。。
def gcd(a, b):
    while (b > 0):
        a, b = b, a%b
    return a
或者:
def gcd(a, b):
    return gcd(b, a%b) if b > 0 else a
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-16 00:51:00 | 显示全部楼层
本帖最后由 jerryxjr1220 于 2017-5-16 00:57 编辑
当回首遇上转身 发表于 2017-5-16 00:28
首先你这个程序 r 没有赋初值,所以当while g!=0:里面的循环不执行的时候会报“在赋值前引用局部变量'r' ” ...


求最大公约数是有简单的方法,但是int(a/b)是什么鬼?
numpy.math.gcd(24,16)
Out[28]: 8
def gcd(x,y):
    while x>0:
        x,y = y%x, x
    return y


gcd(24,16)
Out[34]: 8

gcd(27,9)
Out[35]: 9

gcd(24,36)
Out[36]: 12
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-16 06:43:20 | 显示全部楼层
jerryxjr1220 发表于 2017-5-16 00:51
求最大公约数是有简单的方法,但是int(a/b)是什么鬼?

手快想错了,好尴尬
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-11 09:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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