本帖最后由 洛阳城 于 2021-6-14 16:46 编辑
这是一个十进制转二进制的程序,函数的功能是传入一个十进制数dec将自动计算对应的二进制数并返回
- def Dec2Bin(dec):
- result = '' # 定义一个字符串变量保存结果
- if dec: # 如果传入的参数大于0
- result = Dec2Bin(dec // 2) # 递归计算,‘//’是整数除法,其结果等于除法计算结果向下取整
- return result + str(dec % 2) # 将计算得到的余数进行拼接并返回
- else:
- return result # 当传入的参数等于0时,返回计算得结果
复制代码
分析代码可以得知,当传入一个非0参数时,程序将不断递归计算该参数对2整除的结果直到该结果等于0,当结果等于0时将执行第8行代码,返回result的值,于是程序将会自动查找result最后一次赋值的结果,也就是第5行;但是第5行又涉及到了函数的调用,需要获取该次调用的返回值,也就是第6行代码,于是程序将在此不断回溯前面的计算结果并进行拼接,也就是倒着求前面每次(dec//2)的结果对2的余数并且拼接起来,直到dec等于传入值后,再次回溯result将等于第2行的none,此时if为假,返回此时的结果
具体过程建议楼主在第4行处设置一个断点然后debug单步执行观察整个代码的运行过程,dec不要设置的太大就好,否则步骤会很多点起来会很累