一篇帮你搞定C语言“套娃”(递归)

2023-11-05 21:40

本文主要是介绍一篇帮你搞定C语言“套娃”(递归),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

套娃(递归)

  • 前言
  • 什么是递归?
    • 递归的两个必要条件
    • 练习1
    • 练习2
  • 总结

前言

前面呢,我们介绍了C语言的函数内容,这次给大家介绍一下C语言的”套娃“(递归)。递归可以把我们日常的大事小事化,那么由我来带大家了解和深入递归。

什么是递归?

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

注意前方高能
给大家写一个史上最简单递归代码。

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

运行结果>
在这里插入图片描述
可以看出代码进入了死循环。
我们先来分析一下这个代码>第一次执行打印"hehe"然后接着调用main函数,再打印"hehe",再调用,再打印,就像无限递归一样,就好比镜子里面有个镜子镜子里面有个镜子一直循环下去,但是程序到最后会崩掉(栈溢出了),我们打断点调试一下>
在这里插入图片描述
可以看到他会报出Stack overflow(栈溢出)的异常
在这里插入图片描述
由上面内存图我们可以看出在执行mian函数的时候会一直调用main函数,而调用的同时会在栈区上开辟内存空间,照这样递归下去迟早会出现栈溢出,最终程序崩溃,所以说上面的代码是一个错误代码,会发生错误的递归。
那么为了避免以上的情况发生,我们必须要对递归做出限制条件。

递归的两个必要条件

  • 存在限制条件,当满足这个限制条件的时候,递归便不再继续。
  • 每次递归调用之后越来越接近这个限制条件

我们通过几道典型的题目来深入理解一下套娃思路>

练习1

接受一个整型值(无符号),按照顺序打印它的每一位。 例如: 输入:1234,输出 1 2 3 4

.我们来试着分析一下>
如何得到每一位数字呢,我们画图看一下
在这里插入图片描述
我们用1234%10可以得到他的个位4,再对1234/10可以去掉个位得到123,再对123%10可以得到个位3,然后再对123/10去掉个位得到12,这样依次下去可以得到1234的每一位数字。
我们再来画图看一下
在这里插入图片描述
我们可以把代码拆分成上面这样,当n是一位数的时候不在才分,然后我们看看代码实现>

void print(int n)
{if (n > 9){print(n / 10);}printf("%d ", n % 10);
}
int main()
{int num = 1234;print(num);return 0;
}

我们让代码运行试试>
在这里插入图片描述
ok没问题是我们要的结果,那代码该怎么理解呢,首先我们要知道递归 的递—“递推”、归—“回归”(递归递归先递再归!)
我们来把代码单独拿出来分析一下>
在这里插入图片描述
红色的线是,蓝色的线是,看完这个图相信大家已经能够很好的理解递归的过程了。
再来回过头看看这句话:

只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。

这就是递归的特点。
那么我们来强调两个重点>
在这里插入图片描述
n>9是保证递归能够停下来,n/10是保证递归能够正常按照我们的需求进行下去!
在这里插入图片描述

练习2

求一个数的阶乘(递归实现不考虑溢出)

参考代码:

int factorial(int n)
{if (n <= 1)return 1;elsereturn n * factorial(n - 1);
}int main()
{int n = 5;int print_factorial = factorial(5);printf("%d", print_factorial);return 0;
}

我们再画图分析一下代码>
在这里插入图片描述
还是一样红色的线是,蓝色的线是!!!
看了这个图,大家对递归就有了更深一层次的理解!
提示:

  1. 许多问题是以递归的形式进行解释的,这只是因为它比非递归的形式更为清晰。
  2. 但是这些问题的迭代实现往往比递归实现效率更高,虽然代码的可读性稍微差些。
  3. 当一个问题相当复杂,难以用迭代实现时,此时递归实现的简洁性便可以补偿它所带来的运行时开
    销。

总结

以上就是我为大家介绍的C语言“套娃”的基本思想,相信大家看了以上内容一定会对递归有更深层次的理解。
种一棵树的最好时间是十年前,其次是现在! 把握好当下,合理利用时间努力奋斗,相信大家一定会实现自己的目标!加油!
创作不易,辛苦各位小伙伴们动动小手,三连一波~~~,本文中也有不足之处,欢迎各位随时私信点评指正!

这篇关于一篇帮你搞定C语言“套娃”(递归)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/352677

相关文章

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou

C 语言的基本数据类型

C 语言的基本数据类型 注:本文面向 C 语言初学者,如果你是熟手,那就不用看了。 有人问我,char、short、int、long、float、double 等这些关键字到底是什么意思,如果说他们是数据类型的话,那么为啥有这么多数据类型呢? 如果写了一句: int a; 那么执行的时候在内存中会有什么变化呢? 橡皮泥大家都玩过吧,一般你买橡皮泥的时候,店家会赠送一些模板。 上