数据结构学习笔记--递归

    递归:一个函数自己直接或间接调用自己。

    函数的调用:当在一个函数的运行期间调用另一个函数时,在运行被调函数之前,系统需要完成三间事:1、将所有的实际参数、返回地址(当被调函数完成后,接下来要运行的语句的地址)等信息传递给被调用函数保存。2、为被调函数的局部变量(也包括形参)分配存储空间。3、将控制转移到被调函数的入口。

    从被调函数返回主调函数之前,系统也要完成三件事:1、保存被调函数的返回结果(等会会被释放)。2、释放被调函数所占的存储空间(静态的存储空间,函数调用完毕,其局部变量及形参被释放)。3、依照被调函数保存的返回地址将控制转移到调用函数。

    系统为一个函数只分配一个代码区,即使函数被使用多次。

    当有多个函数相互调用时,按照“后调用先返回”的原则。上述函数之间信息传递和控制转移必须借助“栈”来实现,即系统将整个程序运行时所需的数据空间安排在一个栈中,每当调用一个函数时,就在栈顶分配一个存储区,进行压栈操作;每当一个函数退出时,就释放它的存储区,进行出栈操作,当前运行的函数永远都在栈顶位置。

    递归满足三个条件:1、递归必须得有一个明确的终止条件;2、该函数所处理的数据规模必须在递减(n借助n-1,n-1借助n-2);3、这个转化必须是可解的。

    循环和递归:循环可以用递归来实现

    递归:易于理解,但速度慢,存储空间大(浪费时间、空间)

    循环:不易理解,但速度快、存储空间小

    

    汉诺塔伪算法:

    if(n>1) {

    先把A柱子上的前n-1个盘子从A借助C移到B;将A柱子上的第n个盘子直接移到C;再将B柱子上的n-1个盘子借助A移动到C;

    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值