简析递归

对于程序小白,递归思想是不太好理解的,国内相关教材对此的讲解也不够简单易懂,其实这种思想我们在高中数学已经接触过的,只是很少有人把他们联系起来。

其实,递归思想,就是经典证明方法——数学归纳法的一种灵活应用。

先来回顾下数学归纳法吧:

一般地,证明一个与自然数n有关的命题P(n),有如下步骤:
(1)证明当n取第一个值n0时命题成立。n0对于一般数列取值为0或1,但也有特殊情况;
(2)假设当n=k(k≥n0,k为自然数)时命题成立,证明当n=k+1时命题也成立。
综合(1)(2),对一切自然数n(≥n0),命题P(n)都成立。
再来看一个简单的递归函数:

int recurMul(a,n)

{

if (n == 1)

return a;

else

return a + recurMul(a,n - 1);

}


这是个用递归思想来求正整数a x n的值的函数,简单分析下,它其实就是数学归纳法的应用。

首先,n = 1是,a x 1 = a, 是一定成立的

 [(1)证明当n取第一个值n0时命题成立。n0对于一般数列取值为0或1]

其次,假定recurMul(a,n - 1)成立,recurMul(a,n) = a + recurMul(a,n - 1)也是一定成立的。

[(2)假设当n=k(k≥n0,k为自然数)时命题成立,证明当n=k+1时命题也成立。]

所以,该递归函数满足了数学归纳法(1)(2)两个条件,recurMul(a,n)肯定也是成立的,我们就可以通过

recurMul(a,n)来求a x n的值了。



阅读更多
个人分类: 学习笔记
上一篇也谈规范编程
下一篇C语言编程易错要点
想对作者说点什么? 我来说一句

STL简析入门基础学习

2011年05月16日 61KB 下载

简析搜索引擎实现原理

2010年12月13日 535KB 下载

B2C电子商务推广方案简析

2011年12月11日 29KB 下载

Discuz!NT 缓存设计简析

2010年08月19日 103KB 下载

ThinkPHP2.1.0 RBAC类使用简析.chm

2011年09月13日 309KB 下载

Android-Camera-架构及应用简析

2017年06月01日 588KB 下载

没有更多推荐了,返回首页

关闭
关闭