当前位置: 首页 > 编程笔记 >

C语言的递归思想实例分析

公良照
2023-03-14
本文向大家介绍C语言的递归思想实例分析,包括了C语言的递归思想实例分析的使用技巧和注意事项,需要的朋友参考一下

本文实例分析C语言的递归思想,分享给大家供大家参考之用。具体方法如下:

通俗点来说,递归就是自己调用自己。

递归的难点一是理解递归的执行调用过程,二是设置一个合理的递归结束条件

下面来看一段摘自书中的简单程序:

#include <STDIO.H>
long fact(int n);
long rfact(int n);
int main(void)
{
 int num;
 printf("This program calculates factorials.\n");
 printf("Enter a value in the range 0-12 (q to quit):\n");
 while(scanf("%d",&num)==1)
 {
 if(num<0)
  printf("No negative numbers,please.\n");
 else if (num>12)
 {
  printf("Keep input under 13.\n");
 }
 else
 {
  printf("loop:%d factorial=%d\n",num,fact(num));
  printf("recursion:%d factorial=%d\n",num,rfact(num));
 }
 }
}

long fact(int n)
{
 long ans;
 for (ans=1;n>1;n--)
 {
 ans*=n;
 }
 return ans;
}

long rfact(int n)
{
 long ans;
 if (n>0)
 {
 ans=n*rfact(n-1);
 } 
 else
 {
 ans=1;
 }
 return ans;
}

该程序用来计算阶乘,分别采用循环和递归实现。用语言来描述一下递归的执行过程吧。
假设计算5!,n=5,分别调用了自己4次,即n分别等于4,3,,2,1。当n等于0时,返回ans=1,这时rfact这个函数才刚刚完整的执行一遍,返回ans=1,

压栈已经完成,开始出栈。

n与ans,分别相乘5次,即ans分别等于1,2,6,24,120(24*5)

即5!=120

我们来看一下n的变化规律

入栈时,n=5,4,3,2,1,

出栈时,n=1,2,3,4,5

递归实质上就是栈

往往容易忽略递归条件不满足后,被调函数把控制权转会主调函数,主调函数继续执行剩余的语句这一过程,而造成迷惘。

其实,所有事情都可以用生活中的事情加以解释,就像四大名著相互相通,可以互相解释一样,做一件事情可以不要求甚至不清楚最后的结果,但是一定要明白这件事情是在做什么,明白这件事情来龙去脉,但是不要死钻牛角尖,静心做学问。

感兴趣的朋友可以测试运行本文实例以加深理解,相信本文所述对大家C程序设计的学习有一定的借鉴价值。

 类似资料:
  • 主要内容:递归的进入,递归的退出,递归的条件,更多关于递归函数的内容一个函数在它的函数体内调用它自身称为 递归调用,这种函数称为 递归函数。执行递归函数将反复调用其自身,每调用一次就进入新的一层,当最内层的函数执行完毕后,再一层一层地由里到外退出。 递归函数不是C语言的专利, Java、 C#、 JavaScript、 PHP 等其他编程语言也都支持递归函数。 下面我们通过一个求阶乘的例子,看看递归函数到底是如何运作的。阶乘 n! 的计算公式如下: 根据公式编写如

  • 内存分布思想概述 通过我们前面对C的学习,我们知道了C就是不断地操作和分配内存类型资源的一种语言,它的核心思想就是如何操作内存。不管是指针还是数组,都是围绕着内存。随着对内存属性的深入,自然而然对于我们理解C的一些编程技巧和更高深的思想是很有帮助的。 内存的属性 大小 不管我们是什么数据类型,在编译器看到这个类型之后,就有一个内存大小为我们服务。只是对于指针而言,还多了一个指向类型的读取方法。 在

  • 我是新的编码和需要作出曼德尔布罗特函数。对于那些不知道的人来说,Mandelbrot集合是一组复数。从本质上讲,你可以从一个复数开始,然后把它平方,然后把它加到原来的复数中。例如,如果我使用数字1,集合将是0、1、2、5、26。。。我从0,1,(1^2)1=2,(2^2)1=5,(5^2)1=26得到这个值。现在,我的递归函数应该使用两个输入来求这个集合的和:一个数字n,它是我们进入集合的距离。例

  • 本文向大家介绍C语言double和float 实例分析,包括了C语言double和float 实例分析的使用技巧和注意事项,需要的朋友参考一下 小数也称实数或浮点数。例如,0.0、75.0、4.023、0.27、-937.198 都是合法的小数。这是常见的小数的表现形式,称为十进制形式。 除了十进制形式,也可以采用指数形式,例如 7.25×102、0.0368×105、100.22×10-2 等。

  • 下面的最小可复制示例包含一个模板,其默认参数类型包含lambda

  • 本文向大家介绍C++ 中二分查找递归非递归实现并分析,包括了C++ 中二分查找递归非递归实现并分析的使用技巧和注意事项,需要的朋友参考一下 C++ 中二分查找递归非递归实现并分析 二分查找在有序数列的查找过程中算法复杂度低,并且效率很高。因此较为受我们追捧。其实二分查找算法,是一个很经典的算法。但是呢,又容易写错。因为总是考虑不全边界问题。 用非递归简单分析一下,在编写过程中,如果编写的是以下的代