有关于递归函数的一些学习记录(Recursion)走楼梯,递归找出最两个数的大公约数,汉诺塔问题

本文主要是介绍有关于递归函数的一些学习记录(Recursion)走楼梯,递归找出最两个数的大公约数,汉诺塔问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


递归函数的定义是指在函数执行的过程中,在函数体中直接或间接的调用了自己,这样的函数就是递归函数。递归函数的使用使得分而制之(Divide and Conquer)的思想得意实现,并在解决循环和一些复杂的求解问题中显示了很好的作用。


问题一:说,一个人在爬一个楼梯时,一次可以走一个台阶也可以走两个台阶,问这个人走到第九个台阶有多少种走法?

这是我在2013年春参加南京大学计算机系研究生复试的时候,被问到了这样一个问题,

如果我们不能用递归的思想来解决此类问题的话,这类问题的复杂程度可想而知。若我们理清思路,可得:

当楼梯为第 n=1层时,只有1种走法;当n=2层时,会有两种走法;

所以 f(1)=1;f(2)=2;

而当一个人处于第n层时,它可由第n-1层用一 步迈上去,也可以由第n-2层,1步迈两层上去。所以 f(n)=f(n-1)+f(n-2);

这里可能会有人疑问说,当位于第n-2层时不是由两种迈步的方法吗?要明白的是,当用户在第n-2层只迈一步的时候调到第n-1层,这是f(n-1)里面的问题了,故走到第n层的走法就是走到第n-1层加上第n-2层的走法所以

f(n)=f(n-1)+f(n-2);然后用递归函数就解出来了,这里给出函数的实现。这个问题的原形页就是fibonacci的实现问题。

int step(int n)
{if(n==1||n==2)	return n;elsereturn  step(n-1)+step(n-2);
}
问题二:如何用递归实现求两个数的最大公约数问题。

两个数的最大公约数就是可以同时整除这两个数的最大的约数,一般的求法是找到这两个数(设为X,Y)的较小的一个值并赋值给一个变量temp,然后temp依此减小一,直到可以同时被X,Y整除,这里通过循环很容易就可以实现。

下面来介绍怎样通过递归来实现:

根据经典的欧几里得算法也称作(辗转相除算法)两个正整数(a,b)假如a<b,的最大公约数c也是b%a与a的最大公约数,因为b=(b/a)*a+b%a,所以若a和b%a均可整除c,则(b/a)*a也可整除c,从而b也可整除c.又c是a的最大约数,则c也是a和b的最大公约数,所以通过辗转相除可实现递归算法:

int getcd(int a ,int b)
{
return (b==0)?a:getcdd(b,a%b);
}

问题三:汉诺塔问题
汉诺塔的具体情形就不描述了,这里主要讲述思想:
(1)当 n=1时,只需将盘子从A->B.
但n>1时,进行如下的分解:
(1)将n-1个盘子从A->C;
(2)将第n个盘子从A->B;
(3)将n-1个盘子从C->B;
所以看到汉诺塔问题也被我们分解成了小问题,并一步一步分解,知道最后只有一个盘子后然后递归即可,注意这里需要改变参数的位置来改变移动的方向。
void hanoi(char x,char y,char z,int n)
{
if(n==1)
cout<<"1:"<<<"->"<<"<<





这篇关于有关于递归函数的一些学习记录(Recursion)走楼梯,递归找出最两个数的大公约数,汉诺塔问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1031017

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言