python函数是实现代码复用的一种方式_python中的代码复用与函数递归

~代码复用与模块化设计

!所谓的代复用,顾名思义,也就说同一份代码在需要的时候可以被重复使用,有两种形式:一个是函数,一个是对象。

!模块化设计,简单地来讲,就是通过函数或对象封装将程序划分为模块及模块间的表达,这样就有了两种关系,一个是主程序与子程序之间的关系,一个是子程序和子程序之间的关系。

在模块化设计的时候,我们需要注意模块内部紧耦合,模块之间松耦合。

~函数递归的理解

!函数递归就是在函数定义中调用函数自身的方式。

!我们在编写函数递归的时候,注意把握链条、基例这两大关键特征。基例就是指那些不需要再次递归的部分,比如我们在编写斐波那契数列的时候,当n=1,n=2时,f(1)=1;f(2)=2,这部分为基例;链条就是其余需要我们在函数中进行递归的部分。

~函数递归的调用过程

!递归的实现:递归就是函数+分支语句

递归本来就是一个函数,需要函数定义的方式进行描述;在函数内部,采用分支语句对输入参数进行判断。

~函数递归的实例:汉诺塔

!  代码如下

count=0

def hanoi(n,src,dst,mid):

global count

if n==1:

print("{}:{}-->{}".format(1,src,dst))

count+=1

else:

hanoi(n-1,src,mid,dst)

print("{}:{}-->{}".format(n,src,dst))

count+=1

hanoi(n-1,mid,dst,src)

hanoi(3,"A","C","B")

print(count)

汉诺塔的理解方式:

首先我们先假设一个圆盘的形式,那么我们就直接从第一根柱子挪到第三根柱子上面。如果我们有两块以上的圆盘(假设为n),这样我们直接思考第n个圆盘和n-1个圆盘之间的关系,我们会发现他们之间的关系是,将n-1个圆盘放在第二根柱子上,把第n个圆盘放在第三根柱子上,然后再把n-1个圆盘放在第三根柱子上面。其余的步骤就类似了,就是我们只需要考虑n和n-1之间的关系。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值