首页
学习
活动
专区
圈层
工具
发布

C语言函数递归_c语言递归举例

今天说一说C语言函数递归_c语言递归举例,希望能够帮助大家进步!!! 文章目录 函数递归 什么是递归?...递归的俩个必要条件 代码引例1 栈溢出(Stack Overflow) 合理使用递归 代码引例3 代码引例4 解释要合理使用递归 结束语 函数递归 程序调用自身的编程技巧称为递归 recursion)...函数自己调用自己就是递归 你也可以理解成是一种嵌套结构,但递归分为俩部分,第一是“递”,进入嵌套结构。...第一次接触递归都会很懵,慢慢理解这个过程就明白了。 什么是递归? 递归做为一种算法在程序设计语言中广泛应用。...当一个问题相当复杂,难以用迭代实现时,此时递归实现的简洁性便可以补偿它所带来的运行时开销 结束语 本人是学c小白,这些是近期学习整理总结,有什么不对欢迎大家指正,我会继续努力,谢谢~!

14.5K32

【C语言】函数递归

前言: 在 C 语言函数学习之旅中,递归是一个绕不开的重要话题。它不仅是一种编程技巧,更是一种解决问题的独特思路。...本文将从递归的基本概念出发,深入剖析其限制条件,通过实例演示递归的应用,并对比递归与迭代的优劣,帮助你彻底掌握 C 语言中的函数递归。 一、递归是什么?...在 C 语言中,递归本质上是函数自己调用自己的一种行为,它将一个大型复杂的问题层层拆解为与原问题相似但规模更小的子问题,直到子问题无法再拆分,最终通过子问题的解逐步推导出原问题的解。...0; } 这段代码中,main函数在自身内部调用了自己,符合于函数递归的定义。...缺点 栈溢出风险:在 C 语言中,每一次函数调用都会在栈区申请一块栈帧空间来保存局部变量等信息。如果递归层次过深,会占用大量的栈空间,导致栈溢出错误。

27110
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    c语言函数递归

    函数递归 1.什么是递归 递归是什么? 递归是学习C语⾔函数绕不开的⼀个话题,那什么是递归呢? 递归其实是⼀种解决问题的⽅法,在C语⾔中,递归就是函数⾃⼰调⽤⾃⼰。...写⼀个史上最简单的C语⾔递归代码: #include int main() { printf("hehe\n"); main();//main函数中⼜调⽤了main函数 return...4.递归与迭代 递归是⼀种很好的编程技巧,但是和很多技巧⼀样,也是可能被误⽤的,就像举例1⼀样,看到推导的 公式,很容易就被写成递归的形式: Fact函数是可以产⽣正确的结果,但是在递归函数调⽤的过程中涉及...** 在C语⾔中每⼀次函数调⽤,都需要为本次函数调⽤在内存的栈区,申请⼀块内存空间来保存函数调 ⽤期间的各种局部变量的值,这块空间被称为运⾏时堆栈,或者函数栈帧。...函数不返回,函数对应的栈帧空间就⼀直占⽤,所以如果函数调⽤中存在递归调⽤的话,每⼀次递归 函数调⽤都会开辟属于⾃⼰的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。

    21810

    C语言:函数递归

    一、什么是递归 递归式一种解决问题的方法,在C语言中,递归就是自己调用自己。...递归中的递就是递推的意思,归就是回归的意思 int main() { printf("hehe\n"); main();//main函数中⼜调⽤了main函数 return 0; } 以上就是一个简答的递归程序...在C语⾔中每⼀次函数调⽤,都要需要为本次函数调⽤在栈区申请⼀块内存空间来保存函数调⽤期间 的各种局部变量的值,这块空间被称为运⾏时堆栈,或者函数栈帧。        ...函数不返回,函数对应的栈帧空间就⼀直占⽤,所以如果函数调⽤中存在递归调⽤的话,每⼀次递归 函数调⽤都会开辟属于⾃⼰的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。      ...所以如果采⽤函数递归的⽅式完成代码,递归层次太深,就会浪费太多的栈帧空间,也可能引起栈溢出(stack overflow)的问题。

    57110

    C语言-函数递归

    一.什么是递归? 递归就是函数自己调用自己。...Fac函数是可以产生正确的结果,但是在递归函数时调用涉及一些运行时的开销。...在C语言中每一次函数调用,都需要为本次函数调用在内存的栈区,申请一块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,或者函数堆栈。...函数不返回,函数对应的栈帧空间就一直被占用,如果函数调用中存在递归调用的话,每一次递归函数调用会开辟属于自己的栈帧空间,直到函数调用不再继续,开始回归,才逐层释放出栈帧空间。...如果采用这种函数递归的方法完成代码,递归层次太深,就会浪费太多栈帧空间,也可能引起栈溢出(stack overflow)的问题。

    20110

    函数递归【C语言】

    什么是递归 递归是学习C语言函数绕不开的一个话题,那什么是递归呢? 递归其实是一种解决问题的方法,在C语言中,递归就是函数自己调用自己。...写一个史上最简单的C语言递归代码: #include int main() { printf("hehe\n"); main();//main函数中又调用了main函数 return...在C语言中每一次函数调用,都需要为本次函数调用在内存的栈区,申请一块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,或者函数栈帧。...函数不返回,函数对应的栈帧空间就一直占用,所以如果函数调用中存在递归调用的话,每一次递归函数调用都会开辟属于自己的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。...b; b = c; n--; } return c; } 迭代的方式去实现这个代码,效率就要高出很多了。

    41710

    【C语言】函数递归

    递归 递归是学习C语言函数绕不开的一个话题,那什么是递归呢? 递归其实是一种解决问题的方法,在C语言中,递归就是函数自己调用自己。...写一个史上最简单的C语言递归代码: #include int main() { printf("hehe\n"); main();//main函数中⼜调⽤了main函数 return...在C语言中每一次函数调用,都要需要为本次函数调用在栈区申请一块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,或者函数栈帧。...函数不返回,函数对应的栈帧空间就一直占用,所以如果函数调用中存在递归调用的话,每一次递归函数调用都会开辟属于自己的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。...b; b = c; n--; } return c; } 迭代的方式去实现这个代码,效率就要高出很多了。

    44310

    C语言——函数递归

    一.什么是递归? 递归是一种解决问题的方法,在C语言中,递归就是函数自己调用自己。 具体来讲,函数递归是将一个问题分解为更小的、类似的子问题来解决问题。...原因分析:函数递归栈溢出的原因是递归深度过大,或者没有正确的递归终止条件,导致递归函数无法停止调用,不断地将新的函数压入栈中,最终导致栈空间耗尽。...这也体现出了递归算法的弊端,所以并不是所有的方法都适合用函数递归。...(2)非递归实现 题目分析: 也可以参考上面递归实现的思路,我们可以用三个变量相互替换来解决,a为第一项,b为第二项,c为第三项,运用while()循环,每一次循环n就减1,直到n=2,最后输出c。...而非递归方式只需要使用循环来进行迭代计算,减少了函数调用的开销,提高了效率。 节省内存空间:递归方式在递归过程中需要维护函数调用栈,消耗了额外的内存空间。

    17500

    【C语言】函数和函数递归

    形式参数当函数调用完成之后就自动销毁了。因此形式参数只在函数中有效。...但是具体是不是存在,函数 声明决定不了。 函数的声明一般出现在函数的使用之前。要满足先声明后使用。 函数的声明一般要放在头文件中的。...3.2 函数定义: 函数的定义是指函数的具体实现,交待函数的功能实现。 四、函数递归 练习1 调用函数自己本身,例如,接受一个整型值(无符号),按照顺序打印它的每一位。...{ char arr[] = "bit"; int len = my_strlen(arr); printf("%d\n",len); return 0; } 不创建临时变量----递归...; 递归的方法–把大事化小,首先把字符串首地址传入函数,然后判断字符不是’ \0 '就调用函数本身 my_strlen(“bit”); 1+my_strlen(“it”); 1+1+my_strlen

    35210

    c语言回顾-函数递归

    基本情况是指当问题达到某个特定条件时,不再需要递归调用,可以直接返回结果。递归情况是指在解决问题的过程中,通过调用自身来缩小问题规模,直到达到基本情况。 在c语言中,递归就是函数自己调用自己。...写一个史上最简单的C语言递归代码: #include int main() { printf("hehe\n"); main();//main函数中⼜调⽤了main函数 return...在C语言中每一次函数调用,都要需要为本次函数调用在栈区申请一块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,或者函数栈帧。...函数不返回,函数对应的栈帧空间就一直占用,所以如果函数调用中存在递归调用的话,每一次递归函数调用都会开辟属于自己的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。...int Fib(int n) { int a = 1, b = 1, c =0; while (n > 2) { c = a + b; a = b; b = c; n--; }

    22810

    【C语言系列】函数递归

    一、递归是什么?递归其实是一种解决问题的方法,在C语言中,递归就是函数自己调用自己。...1.1尾递归尾递归是指一个递归函数在调用自身时,该递归调用是函数的最后一条语句。换句话说,函数在调用自身之后不再执行任何操作,而是直接返回递归调用的结果。这种特殊形式的递归称为尾递归。...在C语言中每⼀次函数调用,都要需要为本次函数调用在栈区申请⼀块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,或者函数栈帧。...函数不返回,函数对应的栈帧空间就⼀直占用,所以如果函数调用中存在递归调用的话,每⼀次递归函数调用都会开辟属于自己的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。...代码如下:int Fib(int n){ int a = 1; int b = 1; int c = 1; while(n>2) { c = a+b; a = b; b = c; n--; } return

    43610

    C语言之函数递归

    一、什么是递归? 在C语言中,递归就是函数自己调用自己。...所以函数是不能这样无限递归下去的,递归必须是有条件的! 1.递归的思想 递归的特点:使用少量的代码,就能完成非常复杂的任务。...在C语言中每一次函数调用,都需要为本次函数调用在栈区申请一块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,或者函数栈帧。         ...函数不返回,函数对应的栈帧空间就⼀直占⽤,所以如果函数调⽤中存在递归调⽤的话,每⼀次递归函数调⽤都会开辟属于⾃⼰的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。         ...; a = b; b = c; n--; } return c; } int main() { int n = 0; scanf("%d", &n); int c = Fib(n)

    40210

    C语言-内联函数、递归函数、指针函数

    前言 这篇文章介绍C语言的内联函数、递归函数、函数指针、指针函数、局部地址、const关键字、extern关键字等知识点;这些知识点在实际项目开发中非常常用,非常重要。...printf("a=%#x\n",&a); printf("b=%#x\n",&b); printf("c=%#x\n",&c); printf("p1=%#x\n",p1); printf...递归函数 什么是递归函数? 子函数直接或者间接的方式调用自己的过程叫做递归。 函数自己调用自己的过程—递归。 递归函数注意事项:必须有终止条件。...return 0; } //计算字符串长度 int func(char *p) { if(*p=='\0') { return 0; } return 1+func(p+1); } /* 演示递归函数的返回过程...: a(); //3 int a() { return 1+b(); } int b() { return 1+c(); } int c() { return 1; } */

    95820

    C语言--函数递归与迭代

    递归在书写的时候,有两个必要条件: 1.递归存在限制条件,但凡满足这个限制条件时,递归便不再继续 2.每次递归调用之后越来越接近这个限制条件 递归的思想: 把大事化小事 递归其实就是函数自己调用自己 /...,一直打印hehe 总而言之,在函数中再次调用自己就是递归 如果递归无限的递归下去,就会出现这样的错误,栈溢出 // 每一次函数调用,都要为这次函数调用分配内存空间是内存的栈区上分配的, 如果无限的递归调用函数...,递归便不再继续 2.每次递归调用之后越来越接近这个限制条件 递归的思想: 把大事化小事 递归其实就是函数自己调用自己 //int main() //{ // printf("hehe\n");...// main();//再次调用main函数自己 // return 0; //} 输出结果就是程序进入死循环,一直打印hehe 总而言之,在函数中再次调用自己就是递归 如果递归无限的递归下去...,就会出现这样的错误,栈溢出 // 每一次函数调用,都要为这次函数调用分配内存空间是内存的栈区上分配的, 如果无限的递归调用函数,就会将栈区空间使用完, 就会出现栈溢出的现象 //递归---求n的阶乘

    42010

    【C语言】函数递归(超详解)

    递归是什么? 递归是学习C语⾔函数绕不开的⼀个话题,那什么是递归呢? 递归其实是⼀种解决问题的⽅法,在C语⾔中,递归就是函数⾃⼰调⽤⾃⼰。...写⼀个史上最简单的C语⾔递归代码: #include int main() { printf("hehe\n"); main();//main函数中⼜调⽤了main函数 return...在C语⾔中每⼀次函数调⽤,都要需要为本次函数调⽤在栈区申请⼀块内存空间来保存函数调⽤期间 的各种局部变量的值,这块空间被称为运⾏时堆栈,或者函数栈帧。...函数不返回,函数对应的栈帧空间就⼀直占⽤,所以如果函数调⽤中存在递归调⽤的话,每⼀次递归 函数调⽤都会开辟属于⾃⼰的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。...c; n--; } return c; } 迭代的⽅式去实现这个代码,效率就要⾼出很多了。

    1.2K00

    【C语言基础】:函数递归详解

    函数递归的概念 函数递归指的是在函数内部调用自身的过程。 具体而言,递归函数通过将一个问题分解为更小的、类似的子问题来解决问题。 2....递归函数的定义 递归函数的定义通常包括以下几个要素: 基本情况(Base Case):递归函数必须包含一个或多个基本情况,即能够直接解决的最简单的问题。当函数达到基本情况时,递归将停止。...非递归的实现 题目分析: 也可以参考上面递归实现的思路,我们可以用三个变量相互替换来解决,n1为第一项,n2为第二项,c为第三项,运用while()循环,每一次循环n就减1,直到n=2,最后输出c。...代码实现 #include int Fib(int n) { int a = 1; int b = 1; int c = 1; while (n >= 3) { c =...a + b; a = b; b = c; n--; } return c; } int main() { int n = 0; scanf("%d", &n); int ret =

    1.7K10

    C语言中的函数递归

    C语言中的函数递归 函数递归 C语言中的函数递归 什么是递归 递归必须注意的事 递归练习题 1接受一个整型(无符号),按顺序打印每一位 2用递归求n的k次方 3编写函数不用许创建临时变量,求字符长度 青蛙跳台阶...递归缺点 什么是递归 程序调用自生的编程技巧称作递归。...递归必须注意的事 1存在限制条件,当满足这个条件时,递归便不在继续,(也就是说要有一个临界值) 2每次递归后都会接近临界值,且递归层次不要太深。...,求字符长度 引入一个知识点,当你函数调用传送的是一个数组时,数组名其实传递的是数组首元素的地址。...1递归会导致函数的多次调用,而每次函数调用过程中都会在程序的调用栈(call stack)所开辟空间,但是栈区的空间是有限的当递归的层次太深时就会出现栈溢出(strack overflow). 2递归可能会导致函数的计算可能会变多如斐波那契数列的计算

    1.2K10

    【C语言】函数递归总结

    之前我总结完函数的相关知识,只差个函数递归,这篇着重讲解一下函数递归 1.什么是递归 递归其实是一种解决问题的方法,在C语言中,递归就是函数自己调用自己。...#include int main() { printf("hehe\n"); main();//main函数中⼜调⽤了main函数 return 0; } 上述就是一个简单的递归程序...return 1; else return n*Fact(n-1); } Fact函数是可以产生正确的结果,但是在递归函数调用的过程中涉及一些运行时的开销。...在C语言中每一次函数调用,都要需要为本次函数调用在栈区申请一块内存空间来保存函数调用期间 的各种局部变量的值,这块空间被称为运行时堆栈,或者函数栈帧。...函数不返回,函数对应的栈帧空间就⼀直占用,所以如果函数调用中存在递归调用的话,每一次递归 函数调用都会开辟属于自己的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。

    29910
    领券