递归介绍

递归:就是函数自己调用自己。 子问题须与原始问题为同样的事,或者更为简单;
递归通常可以简单的处理子问题,但是不一定是最好的。

对于递归要分清以下概念:

  • 自己调用自己
  • 递归通常不在意具体操作,只关心初始条件上下层的变化关系
  • 递归函数需要有临界停止点,即递归不能无限制的执行下去。通常这个点为必须经过的一个数。
  • 递归通常能被其他方案替代(栈、数组正向求)。

认识递归,递归函数通常简易但是对于初学者可能很难取理解它。拿一个递归函数来说。

static void digui()
{System.out.println("bigsai前");digui();System.out.println("bigsai后");
}

是一个递归吧?不是正常递归没有结束条件,自己一致调用自己死循环
那正确的递归应该这样

static void digui(int time)
{if(time==0) {}//time==0不执行else {System.out.println("bigsai前time: "+time);digui(time-1);System.out.println("bigsai后time: "+time);   }
}

对于这样一种递归,它的执行流程大致是这样的

所以,调用dugui(5)在控制台输出是这样的

那么,我想你对递归函数执行的流程应该有所了解了吧。

递归求阶乘

n!=n*(n-1)*-----*1=n!=n*(n-1)
所以阶乘的上下级的关系很容易找到。我们假设一个函数jiecheng(n)为求阶乘的函数。
这个阶乘,你可以这样命名:

int jiecheng(int n)
{int va=1;for(int i=n;i>0;i--){va*=i;}return i;
}

但是你还可以简便这样:

static int jiecheng(int n)
{if(n==0)//0的阶乘为1{return 1;}else {return n*jiecheng(n-1);//return n*(n-1)*jiecheng(n-2)=-------}
}

运行流程为这样:

递归求斐波那契

按照上述思想,我们假设求斐波那契设成F(n);
首先,斐波那契的公式为:

  • F[n]=F[n-1]+Fn-2
  • 也就是除了n=1和2特殊以外,其他均是可以使用递推式。

那么递推实现的代码为:

static long F(int n)
{if(n==1||n==2) {return 1;}else {return F(n-1)+F(n-2);}
}

其实它的调用流程为:

当然,其效率虽然不高,可以打表优化,后面可能还会介绍矩阵快速幂优化!

递归解决汉诺塔

汉诺塔是经典递归问题:

相传在古印度圣庙中,有一种被称为汉诺塔(Hanoi)的游戏。该游戏是在一块铜板装置上,有三根杆(编号A、B、C),在A杆自下而上、由大到小按顺序放置64个金盘(如下图)。游戏的目标:把A杆上的金盘全部移到C杆上,并仍保持原有顺序叠好。操作规则:每次只能移动一个盘子,并且在移动过程中三根杆上都始终保持大盘在下,小盘在上,操作过程中盘子可以置于A、B、C任一杆上。

  1. 如果A只有一个(A->C)
  2. 如果A有两个(A->B),(A->C),(B->C)
  3. 如果A有三个(A->C),(A->B),(C->B),(A->C),(B->A),(B->C),(A->C).
  4. 如果更多,那么将会爆炸式增长。

可以发现每增加一步,其中的步骤会多很多。但是不妨这样想:

  • 当有1个要从A->C时,且已知移动方式。使用函数表示move(a->c)。同理其他move操作。
  • -------省略中间若干步骤不看,用递归思想看问题

分析n个从a—>cn-1个a—>c有什么联系?(hannuo(n)—>hannuo(n-1)有啥关系)
假设有n个盘子

  • hannuo(n-1)之后n-1个盘子从A—>C.
  • 此时剩下底下最大的,只能移动到B,move(A,B)
  • 那么你是否发现什么眉目了,只需原先的huannuo(n-1)相同操作从C—>B即可完成转移到B;那么我们的之前函数应该写成hannuo(n-1,A,C)但是又用到B,所以把B传进来hannuo(n-1,A,B,C)先表示为从n-1个从A(借助B执行若干操作)转到C
  • 这一系列操作使得将n个盘子从A—>B但是我们要的是A—>C才是需要的hannuo(n,A,B,C);那么我们只需要更改下hannuo(n-1,----)顺序就好啦!

经过上面分析,那么完整的操作为:

package 递归;
public class hannuota {static void move(char a,char b){System.out.println("移动最上层的"+ a+ "到"+ b+ "t");}static void hannuota(int n,char a,char b,char c)//主要分析每一大步对于下一步需要走的。{if(n==1) {move(a,c);}//从a移到celse{hannuota(n-1,a,c,b);//将n-1个从a借助c移到bmove(a,c); //将第n(最后一个)从a移到c。hannuota(n-1,b,a,c);//再将n-1个从b借助a移到c}}public static void main(String[] args){hannuota(5,'a','b','c');}
}

总结

其实递归在某些场景的效率是很低下的。尤其是斐波那契.从图你就可以发现一个简单的操作有多次重复。因为它的递归调用俩个自己.那么它的递归的膨胀率是指数级别的,重复了大量相同计算。当然这种问题也有优化方案的:

  • 从前往后打表计算,采用类似动态规划的思想。从前往后考虑。比如斐波那契F[n]=F[n-1]+F[n-2];那么我用数组储存。从第三项开始F[3]=F[2]+F[1](均已知),再F[4]=F[3]+F[2]-----这样,时间复杂度是O(N),线性的。
  • 当然,对于阶乘那种递归虽然时间是没有减少,但是如果需要多次访问一个阶乘,那么可以采用同样思想(打表)解决问题。

最后,笔者能力有限,如果有描述不恰当还请指正,感谢前面动态图(未找到原作者)和汉诺塔动图开源作者isea533的开源作品。同时,如果有喜欢学习交流的欢迎关注笔者公众号:bigsai 回复数据结构赠送精美资料一份!

labview求n阶乘的和_递归算法(从阶乘、斐波那契到汉诺塔的递归图解)相关推荐

  1. 数据结构与算法—递归算法(从阶乘、斐波那契到汉诺塔的递归图解)

    目录 递归介绍 递归求阶乘 递归求斐波那契 递归解决汉诺塔 总结 递归介绍 递归:就是函数自己调用自己. 子问题须与原始问题为同样的事,或者更为简单: 递归通常可以简单的处理子问题,但是不一定是最好的 ...

  2. 递归算法小结(数的阶乘、斐波那契和汉诺塔问题)

    递归是一项重要的编程技术,它让函数可以从函数体内部调用自身.递归通常把一个大型复杂的问题层层简化为一个,与原问题相似的规模较小的问题来求解,使用递归策略只需少量的程序就可描述出解题过程所需要的多次重复 ...

  3. C语言用递归求斐波那契数,让你发现递归的缺陷和效率瓶颈

    C语言用递归求斐波那契数,让你发现递归的缺陷和效率瓶颈 分享到: QQ空间 新浪微博 腾讯微博 豆瓣 人人网 递归是一种强有力的技巧,但和其他技巧一样,它也可能被误用. 一般需要递归解决的问题有两个特 ...

  4. python利用列表计算斐波那契数列前30项_使用python计算斐波那契数列

    定义 斐波那契数列(Fibonacci sequence),又称黄金分割数列. 因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子 (假定每对大兔每月能生产一对小兔 ...

  5. 递归算法(python),汉诺塔问题,斐波那契数列,一个简单的递归实例,用递归实现阶乘,用递归查看目录及文件

    https://blog.csdn.net/hanhanwanghaha宝藏女孩 欢迎您的关注! 欢迎关注微信公众号:宝藏女孩的成长日记 让这个可爱的宝藏女孩在努力的道路上与你一起同行! 如有转载,请 ...

  6. python编写递归函数、求斐波那契数列_利用Python实现斐波那契数列的方法实例

    今天我们来使用Python实现递归算法求指定位数的斐波那契数列 首先我们得知道斐波那契数列是什么? 斐波那契数列又叫兔子数列 斐波那契数列就是一个数列从第三项开始第三项的值是第一项和第二项的和依次类推 ...

  7. python汉诺塔递归算法流程图_详解汉诺塔Python递归程序

    学习递归时,很多小伙伴对汉诺塔的递归算法非常疑惑,不清楚那么复杂的移动过程,为何用四五行代码就给解决了.汉诺塔问题:有三根柱子A,B,C.A柱上有若干碟子,每次移动一块碟子,小的只能叠在大的上面,把所 ...

  8. python面向过程实践汉诺塔_递归汉诺塔-和递归汉诺塔相关的内容-阿里云开发者社区...

    多柱汉诺塔最优算法设计探究 多柱汉诺塔最优算法设计探究 引言 汉诺塔算法一直是算法设计科目的最具代表性的研究问题,本文关注于如何设计多柱汉诺塔最优算法的探究.最简单的汉诺塔是三个柱子(A.B.C),因 ...

  9. c语言斐波那契数列_剑指Offer-10-I.斐波那契数列

    题目 题目描述 写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项.斐波那契数列的定义如下: F(0) = 0, F(1) = 1 F(N) = F(N - 1) + F(N - ...

最新文章

  1. 2021年4月自动驾驶领域重要动态速览
  2. spring 集成hibernate
  3. Bash Shell学习笔记二
  4. python引入redis_使用python向Redis批量导入数据
  5. Color类提供的颜色
  6. Python—实现ssh客户端(连接远程服务器)
  7. 高可用高并发的 9 种技术架构!
  8. Windows下Weblogic 12c单机安装与部署
  9. 内置炊具行业调研报告 - 市场现状分析与发展前景预测
  10. php phonegap,PHP数据是无休止的加载,jquery,phonegap
  11. 分辨率_电视分辨率多少合适
  12. fileurlwithpath urlwithstring 这俩有啥区别吗
  13. springCloud 之 Eureka高可用配置
  14. TZOJ 3244 Happy YuYu's Birthday(数学几何)
  15. tespeed - 测试网速的Python工具
  16. RF自动化测试框架(一)
  17. Google服务和软件大全
  18. 惠普HP打印机打印全黑是什么原因
  19. 高清计算机主板,主板天梯图2020最新版
  20. Java面向对象与代码编写

热门文章

  1. equipment hierarchy download不完整的一个原因
  2. MPC class get last modified - how to implement
  3. SAP Hybris Enterprise Commerce的一些有用链接 - 保证持续更新
  4. 如何在ABAP Netweaver和CloudFoundry里记录并查看日志
  5. 截屏当前界面_华为手机居然有这3种神奇的截屏方法,用过后,我就再也离不开了...
  6. python解释器的提示符是shell嘛_从PowerShell语法错误运行Python脚本
  7. 职高学的计算机单招考试能换专业吗,高职单招可以随便选专业吗
  8. 网上学c语言推荐课程网站,C语言教学网络课程网站论文
  9. linux查看主机端口进程命令
  10. html连在一起的选择器,请问关于css选择器的问题:两个类选择器连在一起是什么意思?...