iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言函数的递归怎么调用
  • 893
分享到

C语言函数的递归怎么调用

2023-06-30 10:06:57 893人浏览 泡泡鱼
摘要

这篇文章主要讲解了“C语言函数的递归怎么调用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言函数的递归怎么调用”吧!一、什么是递归程序调用自身的编程技巧称为递归( recursion)

这篇文章主要讲解了“C语言函数的递归怎么调用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言函数的递归怎么调用”吧!

一、什么是递归

程序调用自身的编程技巧称为递归( recursion) 。递归做为一种算法在程序设计语言中广泛应用。一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的主要思考方式在于:把大事化小

递归的两个必要条件:

  • 存在限制条件,当满足这个限制条件的时候,递归便不再继续。

  • 每次递归调用之后越来越接近这个限制条件。

int main(){printf("hehe\n");main();return 0;}

函数自己调用自己,一直打印 “hehe” 但是一会程序自己会停下来。这不是真正的递归,是一个死循环(不满住递归的两个条件)

递归实现:接收一个整型值(无符号),按照顺序打印它的每一位。

例如:

输入:1234

输出:4321

void print(unsigned int n){if (n > 9){print(n / 10);}printf("%d", n % 10);}int main(){unsigned int num = 0;scanf("%u", &num);//递归-函数自己调用自己print(num);return 0;}

基本的实现逻辑如图:

C语言函数的递归怎么调用

写递归代码的时候注意:

  • 不能死递归,都有跳出条件,每次递归逼近跳出条件

  • 递归层次不能太深(可能会栈溢出)

二、递归与迭代

求第n个斐波那契数,(可以递归实现也可以迭代实现)(不考虑溢出)
我们知道像:1,1,2,3,5,8,13,21,34…… 这样第n个数等于第n-1个数加上n-2个数的和的一个数列就是斐波那契数列

  • 递归实现求斐波那契数,直接看代码:

int Fib(int n){if (n <= 2)return 1;elsereturn Fib(n - 1) + Fib(n - 2);}int main(){int n = 0;scanf("%d",&n);int ret = Fib(n);printf("%d\n", ret);return 0;}

当我们求很小的斐波那契数时,计算机计算很快。但是当我们要求的一个很大的,比如第50个斐波那契数,计算机就会算很久(大概要五分钟)。大家可以试一试。

为什么会这么慢呢。因为递归实现效率太低,要重复大量的计算(计算层次太多)。

代码实现的基本逻辑如图:

C语言函数的递归怎么调用

我们可以看一下代码在计算过程中 n=3(计算第三个斐波那契数) 这一步要执行的次数:

C语言函数的递归怎么调用

在计算第40个斐波那契数时,要计算三千多万次第三个斐波那契数。可想而知递归实现的效率有多低。而且计算太大还会造成程序崩溃。

  • 循环迭代实现求斐波那契数,直接看代码:

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 c;}int main(){int n = 0;scanf("%d", &n);int ret = Fib(n);printf("%d\n", ret);return 0;}

循环迭代的方式计算很快

提示

  • 很多问题是以迭代的形式进行解释的,这只是因为它比非递归的形式更为清晰。

  • 但是很多问题的迭代实现往往比递归实现的效率更低。虽然代码的可读性稍微差些。

  • 当一个问题相当复杂时,难以用迭代实现时,此时递归实现的简洁性便可以补偿它所带来的运行开销。

感谢各位的阅读,以上就是“C语言函数的递归怎么调用”的内容了,经过本文的学习后,相信大家对C语言函数的递归怎么调用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: C语言函数的递归怎么调用

本文链接: https://www.lsjlt.com/news/328222.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言函数的递归怎么调用
    这篇文章主要讲解了“C语言函数的递归怎么调用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言函数的递归怎么调用”吧!一、什么是递归程序调用自身的编程技巧称为递归( recursion) ...
    99+
    2023-06-30
  • C语言函数的递归调用详情
    目录一、什么是递归二、递归与迭代一、什么是递归 程序调用自身的编程技巧称为递归( recursion) 。递归做为一种算法在程序设计语言中广泛应用。一个过程或函数在其定义或说明中有直...
    99+
    2022-11-13
  • c语言函数的递归调用方法是什么
    C语言函数的递归调用方法是指在函数内部调用自身的过程。递归调用函数可以让程序重复执行相同的操作,直到满足某个条件才停止。递归调用函数...
    99+
    2023-09-04
    c语言
  • C语言的递归函数详解
    目录函数递归什么是递归?递归的俩个必要条件代码引例1栈溢出(Stack Overflow)合理使用递归代码引例3代码引例4解释要合理使用递归总结函数递归 程序调用自身的编程技巧称为递...
    99+
    2022-11-12
  • c语言函数的递归调用要注意哪些事项
    在C语言中,递归调用函数时需要注意以下几个事项:1. 递归的终止条件:递归函数需要定义一个终止条件,当满足这个条件时,递归调用将停止...
    99+
    2023-09-22
    c语言
  • C语言 function recursion函数递归详解
    目录function recursion(函数递归)递归的中心思想为:程序一递归的两个必要条件程序一:程序二:练习求n的阶乘再来道例题function recursion(函数递归)...
    99+
    2022-11-12
  • C语言递归函数如何实现
    这篇文章主要介绍“C语言递归函数如何实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C语言递归函数如何实现”文章能帮助大家解决问题。一、递归的数学思想递归是一种数学上分而自治的思想递归需要有边界条...
    99+
    2023-06-30
  • c语言深入理解函数的递归
    前言:  首先,递归是什么,递归就是在定义函数时,然后在函数里调用这个函数,通俗讲,就是函数自己调用自己。那么递归的好处是什么呢?它能够将复杂的问题,用少量的代码来表示,增加了代码的...
    99+
    2022-11-13
  • C语言怎么运用函数的递归实现汉诺塔
    这篇文章主要讲解了“C语言怎么运用函数的递归实现汉诺塔”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言怎么运用函数的递归实现汉诺塔”吧!1、汉诺塔是如何实现的下面是有三个盘子的示例:从左...
    99+
    2023-07-02
  • C语言用递归函数实现汉诺塔
    目录汉诺塔(Hanoi)是什么?那么,C语言如何实现汉诺塔呢?汉诺塔的基本思路是:具体代码见下(注意点在代码下面):总结汉诺塔(Hanoi)是什么? 一个简单的汉诺塔就如上图所示...
    99+
    2022-11-13
  • C语言超细致讲解函数递归
    目录前言什么是递归递归的两个必要条件题解递归递归与迭代练习题结束语前言 最近被函数递归困恼许久,今天就带领大家一起探秘递归。 什么是递归 程序调用自身的编程技巧称为递归( recur...
    99+
    2022-11-13
  • C语言中函数递归的示例分析
    这篇文章主要介绍C语言中函数递归的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是递归?递归(recursion):程序调用自身的一种编程技巧。如何理解函数递归:从调用自身层面:函数递归就是函数自己调用自...
    99+
    2023-06-29
  • Python函数递归怎么调用
    本篇内容介绍了“Python函数递归怎么调用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!函数递归调用介绍...
    99+
    2022-10-19
  • Scala递归函数怎么调用
    这篇文章主要介绍“Scala递归函数怎么调用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Scala递归函数怎么调用”文章能帮助大家解决问题。1. 概述Scala递归函数是一种函数可以调用自身的函数...
    99+
    2023-07-05
  • C语言函数的基本使用和递归小结
    本章目标 秃头侠们好呀,今天我们一起学习函数! 目标: 本章主要掌握函数的基本使用和递归 函数是什么 数学中我们常见到函数的概念。但是你了解C语言中的函数吗? 维基百科中对函数的定义...
    99+
    2022-11-12
  • C语言函数的基本使用和递归详解
    目录本章目标函数是什么C语言中函数的分类库函数如何学会使用库函数?自定义函数函数的参数函数的调用:函数的嵌套调用和链式访问嵌套调用链式访问函数的声明和定义函数递归什么是递归?递归的两...
    99+
    2022-11-12
  • C语言运用函数的递归实现汉诺塔
    目录1、汉诺塔是如何实现的2、汉诺塔问题画图详解3、汉诺塔问题代码解释总结1、汉诺塔是如何实现的 下面是有三个盘子的示例: 从左到右一次是 A柱 B柱 C柱 A柱:起始位置 B柱:...
    99+
    2022-11-13
  • c语言递归和非递归排序怎么实现
    本篇内容主要讲解“c语言递归和非递归排序怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“c语言递归和非递归排序怎么实现”吧!递归代码流程归并就是把两个或多个序列合并,这里只介绍二路归并,就...
    99+
    2023-06-30
  • c语言递归算法怎么应用
    C语言递归算法可以应用于解决各种问题,特别是涉及到递归结构的问题。以下是一些常见的应用场景:1. 数学问题:计算阶乘、斐波那契数列、...
    99+
    2023-10-07
    c语言
  • C语言深入分析递归函数的实现
    目录一、递归的数学思想二、递归函数三、递归函数设计技巧四、递归函数设计示例一五、递归函数设计示例二六、递归函数设计示例三七、小结一、递归的数学思想 递归是一种数学上分而自治的思想 递...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作