Java教程

【养成记】嵌入式挑战第15天,第二周第四讲-递归函数

本文主要是介绍【养成记】嵌入式挑战第15天,第二周第四讲-递归函数,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

【养成记】嵌入式挑战第15天,第二周第四讲-递归函数

课程章节

物联网/嵌入式工程师 第二周第四讲 1-18 递归函数

课程内容

对C语言中的递归函数做了介绍

学习笔记

1. 概述

概念:在函数体内,自己调用不断的调用自己,直到某个条件满足才结束调用。
这样的函数我们叫做递归函数。

2. 代码示例

//
// Created by au on 2022/9/19.
//
#include <stdio.h>

int factorial(int num) {

    if (num == 0) {
        return 0;
    } else if (num == 1) {
        return 1;
    }
    return num * factorial(num - 1);
}

/**
 * 要求大家用递归函数写一个5!
解析: 5!指的是求5的阶乘,即求5 * 4 * 3 * 2 * 1的值
要求用递归函数实现。
 * @return
 */
int main() {

    int num = 0;
    printf("请输入想要计算的阶乘数:");
    scanf("%d", &num);

    int ret = factorial(num);

    printf("%d的阶乘为: %d", num, ret);
}

运行结果

请输入想要计算的阶乘数:6
6的阶乘为: 720

请输入想要计算的阶乘数:5
5的阶乘为: 120

3. 代码示例

3.1. 递推和回归

图片描述

3.2. 切饼的代码演示

图片描述

图片描述

课程评价

C语言中的递归函数,很多时候可能会用到,代码很简单,但是写出正确且简练的代码其实很不容易,需要多加练习。

这篇关于【养成记】嵌入式挑战第15天,第二周第四讲-递归函数的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!