鱼C论坛

 找回密码
 立即注册
查看: 620|回复: 4

[已解决]python小白关于17讲的小小白问题

[复制链接]
发表于 2018-8-26 13:07:53 | 显示全部楼层 |阅读模式

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

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

x
第一个问题是: 1535259716(1).png 这究竟为什么会报错,并没有什么等于0啊
def gcd(a,b):
    c = 0
    if a>b:
        a,b=b,a
    r0 = a
    r1 = b
    r2 = a % b
            
    while r1 != 0:
        
        r0,r1,r2 =r1,r2,(r1%r2)

    if r1 == 0:
        print("最大公约数是:",r0)
        
第二个问题是: 001cc18583bbce714afe3d9b041c65d.png 这两种结果是一样的 为什么小甲鱼要用这么复杂的方法...我想一定是我的方法有什么弊端... 请大佬指出
最佳答案
2018-8-26 13:26:30
r2 会等于 0 呀~~~
  1. #递归
  2. def gcd(x, y):
  3.     if y:
  4.         return gcd(y, x%y)
  5.     else:
  6.         return x

  7. #非递归
  8. def gcd(x, y):
  9.     while y:
  10.         x, y = y, x%y
  11.     return x
复制代码

2. 老师的方法是迭代,你的是直接调用内建操作符,犯规!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-8-26 13:20:10 | 显示全部楼层
本帖最后由 凌九霄 于 2018-8-26 13:24 编辑

一、你不断地r2=r1 % r2 ,r2就可能为0
二、你用x**y的形式,其实就是调用的pow函数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-8-26 13:26:30 | 显示全部楼层    本楼为最佳答案   
r2 会等于 0 呀~~~
  1. #递归
  2. def gcd(x, y):
  3.     if y:
  4.         return gcd(y, x%y)
  5.     else:
  6.         return x

  7. #非递归
  8. def gcd(x, y):
  9.     while y:
  10.         x, y = y, x%y
  11.     return x
复制代码

2. 老师的方法是迭代,你的是直接调用内建操作符,犯规!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-8-26 13:31:01 | 显示全部楼层
第一个问题,你可以百度下 辗转相除法。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-8-26 14:13:15 | 显示全部楼层
claws0n 发表于 2018-8-26 13:26
r2 会等于 0 呀~~~

2. 老师的方法是迭代,你的是直接调用内建操作符,犯规!
  1. def gcd(a,b):
  2.     if a<=b:
  3.         a,b=b,a
  4.     r0 = a
  5.     r1 = b
  6.     r2 = a % b
  7.             
  8.     while r2 != 0:      
  9.             r0,r1,r2 =r1,r2,(r1%r2)
  10. #用r0表示被除数,r1表示除数,r2表示余数
  11. #只要余数不为0,while就会一直循环下去,直到余数r2=0,此时可以跳出循环,答案就是除数r1
  12.      
  13.     print("最大公约数是:",r1)
复制代码


谢谢,我后来改了下做出来了...
不过看了你的代码后感觉自己写的好复杂... 还没有上到递归... 还是谢谢大佬!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-26 16:34

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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