C/C++教程

【金秋打卡】第十五天c++

本文主要是介绍【金秋打卡】第十五天c++,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

课程名称:趣味c++入门

章节名称:第七章 函数是什么

讲师姓名:Redknot

内容概述:函数的递归调用:

  1. 递归的终止条件是什么? 

必须设计好这一点,否则就会直接爆栈

2.递归被分解后最基本操作是什么?

递归非常适合层级调用关系,每一层都执行相同的操作,这个要素,就是要提取出递归最核心的要素。

3.递归调用传递的参数

参数列表,返回值。参数列表表示给下一层调用需要传递什么,返回值表示上一层调用需要返回什么。

例如需要一个n!

一般我们会写这样子:

#include<stdio.h>

int main()

{

    int i,n,a=1;

    printf("请输入一个数:");

    scanf("%d",&n);

    for(i=1;i<=n;i++)

        a*=i;

    printf("n!=%d",a);

    return 0;

}

如果用递归:

#include<stdio.h>

int fact(int n)

{

    if(n==1)

    {

        return 1;

    }

    else

    {

        return n*fact(n-1);

     }

}

int main()

{

        int x=5;

        int res=fact(x);

        printf("%d\n",res);

        return 0;

}

利用递归的特性,可以很简单得处理一些循环特别复杂的问题,例如:遍历文件夹,遍历二叉树等。

学习心得:学习了函数的递归调用

学习截图:https://img1.sycdn.imooc.com/636904c80001f8e519201080.jpg

这篇关于【金秋打卡】第十五天c++的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!