C语言学习 递归 (分析,习题,拓展)

 

目录

一.递归

1.定义:

2.递归的结构:

3.注意:

4.实例:

5.基本递归习题(计算阶乘):

6.递归习题进阶(斐波那契数列) :

 7.尾递归(简单学习:会用到Stack(栈).知识点):

8.采用递归方法来解决问题,必须符合以下三个条件:

9.拓展(初学者可大致了解一下):

二.结尾


一.递归

1.定义:

一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。

2.递归的结构:

边界条件、递归前进短和递归返回段。

3.注意:

(1) 递归就是在过程或函数里调用自身;

(2) 在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口。

4.实例:

也许之前你在网络上看到过这张图片:

            

实际上这张图就很形象地表达出了递归,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算。

5.基本递归习题(计算阶乘):

问题:计算n!

数学上的计算公式为:n!=n×(n-1)×(n-2)……2×1

使用递归的方式,可得到:                                                                                                                                                                                                                                                                                                               1                    如果  n=0,n=1                                                                                         F(n)=  {                                                                                                                                                            nF(n-1)       如果   n>1                                                                                              如:     以递归的方式计算4!

F(4)=4×F(3)            //递归阶段

    F(3)=3×F(2)

         F(2)=2×F(1)

              F(1)=1  //终止条件

         F(2)=(2)×(1)   // 回归阶段

    F(3)=(3)×(2)

F(4)=(4)×(6)

24                //  递归完成

#include <stdio.h>
 
double factorial(unsigned int i)
{
   if(i <= 1)
   {
      return 1;
   }
   return i * factorial(i - 1);
}
int  main()
{
    int i = 4;
    printf("%d 的阶乘为 %f\n", i, factorial(i));
    return 0;
}

 可得出结果为:

6.递归习题进阶(斐波那契数列) :

#include <stdio.h>
 
int fibonaci(int i)
{
   if(i == 0)
   {
      return 0;
   }
   if(i == 1)
   {
      return 1;
   }
   return fibonaci(i-1) + fibonaci(i-2);
}
 
int  main()
{
    int i;
    for (i = 0; i < 10; i++)
    {
       printf("%d\t\n", fibonaci(i));
    }
    return 0;
}

运行结果为: 

 7.尾递归(简单学习:会用到Stack(栈).知识点):

如果一个函数中所有递归形式的调用都出现在函数的末尾,我们称这个递归函数是尾递归的。当递归调用是整个函数体中最后执行的语句且它的返回值不属于表达式的一部分时,这个递归调用就是尾递归。

8.采用递归方法来解决问题,必须符合以下三个条件:

(1)、可以把要解决的问题转化为一个新问题,而这个新的问题的解决方法仍与原来的解决方法相同,只是所处理的对象有规律地递增或递减。

说明:解决问题的方法相同,调用函数的参数每次不同(有规律的递增或递减),如果没有规律也就不能适用递归调用。

(2)、可以应用这个转化过程使问题得到解决。

说明:使用其他的办法比较麻烦或很难解决,而使用递归的方法可以很好地解决问题。

(3)、必定要有一个明确的结束递归的条件。

      说明:一定要能够在适当的地方结束递归调用。不然可能导致系统崩溃。

9.拓展(初学者可大致了解一下):

(1).电脑空间大致分Heap(堆)Stack(栈)两种。

是用于函数的空间。

电脑调用一个函数,就会使用一层栈;

相反,电脑中一个函数结束(return),就会释放这一层栈,连同在这层栈(这个函数)中定义的所有东西

不在栈中的,应该就在堆中。(这就是定义全区变量与局部变量的用处)

如果调用太多层栈(太多个函数),电脑就会暴空间!

所以说,调用递归函数,就会一层一层地压栈电脑就会暴空间!并不代表不建议用递归,只是作提示而已

(2).递归,就是递(一层一层地调用)归(一层一层地返回),这样会费很多时间!容易超时

但是,我并不是说不用递归,而是说能用递推算法的,最好不用递归算法,(原因你知道)。

(3).递归,是一种算法,特点:函数调用本身。

(4).我们在(1.)说过了,在此说一下:数据结构——栈,可以用递归来实现

(5).递归写出来的C程序一般都很简洁

如:求阶乘

普通:

long long int fac(int n) {
 if (n < 0) return -1;
 if (n == 0) return 1;
 long long int sum = 1;
 for (int i = 2;i <= n;i ++)
  sum *= i;
 return sum;
}

递归:

long long int fac(int n) {
 if (n < 0) return -1;
 if (n == 0) return 1;
 return n * fac(n - 1);
}

有些算法,如搜索与回溯算法,广度优先搜索算法,分治(二分),都将用到递归。

二.结尾

期待接下来的日子继续分享学习......

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三鄯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值