鱼C论坛

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

零基础PYTHON,第17讲,最后两道

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

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

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

x
1. 编写一个函数,利用欧几里得算法(脑补链接)求最大公约数,例如gcd(x, y)返回值为参数x和参数y的最大公约数
def gcd(x, y):
    while y:
        t = x % y
        x = y
        y = t

    return x
   
print(gcd(4, 6))
结果懂,但是还是不清楚为啥,具体过程可以讲下么?

2. 编写一个将十进制转换为二进制的函数,要求采用“除2取余”(脑补链接)的方式,结果与调用bin()一样返回字符串形式
def Dec2Bin(dec):
    temp = []
    result = ''
   
    while dec:
        quo = dec % 2
        dec = dec // 2
        temp.append(quo)

    while temp:
        result += str(temp.pop())
   
    return result

print(Dec2Bin(62))
分开来都明白,但是结合一起就不知道了,能不能也给讲下。为啥视频好简单,练习题好难啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-10-13 08:50:55 From FishC Mobile | 显示全部楼层
弄清欧几里得算法和二进制应该就可以看懂了吧…
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-10-13 09:17:58 | 显示全部楼层
1.循环过程中公约数不变,直到一个变成公约数,一个变成公约数倍数,除出个0,x,y一直趋向公约数

2十进制怎么转二进制的,数学上你懂就懂了,不懂百度,这是软硬件0,1基础
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-10-7 05:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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