news 2026/4/3 13:19:07

C 语言学习历程:(第七章)函数递归・在自我调用中探寻问题的精妙解法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C 语言学习历程:(第七章)函数递归・在自我调用中探寻问题的精妙解法

第七章:函数递归

文章目录

  • 第七章:函数递归
    • 1. 求 n 的阶乘
    • 2. 顺序打印一个整数的每一位
    • 3. 求 n 的 k 次方
    • 4. 递归与迭代
      • 4.1 求第 n 个斐波那契数
  • 总结

函数递归就是函数自己调用自己。其思想是将一个大型复杂问题层层转化为一个与原问题相似,但规模较小的子问题来求解;直到子问题不能再被拆分,递归就结束。递归中的递就是递推的意思,归就是回归的意思。

限制条件:

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

1. 求 n 的阶乘

一个正整数的阶乘是所有小于及等于该数的正整数的积,并且0的阶乘为1

#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>//阶乘//定义阶乘函数intfactorial(intn){if(n==0){return1;}returnfactorial(n-1)*n;}intmain(){//方法一:循环//int num = 1;//for (int i = 1; i <= 10; i++)//{// num *= i;//}//方法二 :递归,逻辑如下// 0!= 1// 1!= 1 = 0! * 1// 2!= 1 * 2 = 1! * 2// 3!= 1 * 2 * 3 = 2! * 3// 4!= 1 * 2 * 3 * 4 = 3! * 4// n! = (n-1)! * nintn=0;scanf("%d",&n);printf("%d",factorial(n));return0;}

2. 顺序打印一个整数的每一位

输入一个整数。按照顺序打印整数的每一位,例如输入:1234 输出: 1 2 3 4

#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>//顺序打印一个整数的每一位// 1 : 1// 12 : 1 2 = print_num(1) 2// 123 : 1 2 3 = print_num(12) 3// 1234 : 1 2 3 4 = print_num(123) 4// n : print_num(n / 10) n % 10voidprint_num(intnum){//方法一if(num/10==0){printf("%d",num);//个位数返回本身}else{print_num(num/10);//递归调用,去掉个位数printf(" %d",num%10);}//方法二//if (num > 9) //不是个位则进行递归//{// print_num(num / 10);//递归调用,去掉个位数//}//printf("%d ", num % 10);//if语句执行完还会打印数字,而不是else的关系}intmain(){intnum=0;scanf("%d",&num);print_num(num);//定义打印每一位数字的函数return0;}

3. 求 n 的 k 次方

输入一个整数 n 递归实现 n 的 k 次方

//递归实现n的k次方// 2^1 = 2// 2^2 = 2^1 *2// 2^3 = 2^2 *2// n^k = n^(k-1) * n//求n的k次方函数intexponent(intn,intk){if(k==1){returnn;//如果是1次方,返回本身}returnexponent(n,k-1)*n;}intmain(){intn=0;intk=0;scanf("%d%d",&n,&k);printf("%d",exponent(n,k));return0;}

4. 递归与迭代

在C语言中每一次函数调用,都需要为本次函数调用在内存的栈区,申请一块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,或者函数栈帧。

函数不返回,函数对应的栈帧空间就⼀直占⽤,所以如果函数调⽤中存在递归调⽤的话,每⼀次递归函数调⽤都会开辟属于⾃⼰的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。 所以如果采⽤函数递归的⽅式完成代码,递归层次太深,就会浪费太多的栈帧空间,也可能引起栈溢出的问题。

当不使用递归,通常就是迭代的方式(通常是循环)

4.1 求第 n 个斐波那契数

计算第n个斐波那契数,这个程序便不适合用递归求解

#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>//递归和迭代//求第n个斐波那契数//1 1 2 3 5 8 13 21 ...:前两个数相加等于后面的数字//第n个斐波那契数字:f(n) = f(n-2) + f(n-1)//递归实现斐波那契会有大量重复计算,效率低下intf_add(intnum){if(num==1||num==2){return1;}else{returnf_add(num-2)+f_add(num-1);}}intmain(){intnum=0;//定义变量接受第几个斐波那契数字scanf("%d",&num);f_add(num);//调用函数printf("%d\n",f_add(num));//打印结果return0;}

迭代实现:

#define_CRT_SECURE_NO_WARNINGS#include<stdio.h>//迭代实现intmain(){intleft_1=1;//最左边第一个数intleft_2=1;//最左边第二个数intnum=0;//定义变量接受第几个斐波那契数字intn=1;//定义变量计算数字,初始值为1scanf("%d",&num);for(inti=0;i<num-2;i++){n=left_1+left_2;//计算当前数left_1=left_2;//更新左边第一个数left_2=n;//更新左边第二个数}printf("%d\n",n);//打印结果return0;}

第八章:操作符详解

总结

本文是在鹏哥 C 语言集训营学习过程中所记录的学习笔记,梳理了核心知识点,同时也记录了本人实操验证的代码案例,供后续学习复盘使用。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 13:39:20

[技术深度]ContextMenuManager核心机制全解析:从原理到实践

[技术深度]ContextMenuManager核心机制全解析&#xff1a;从原理到实践 【免费下载链接】ContextMenuManager &#x1f5b1;️ 纯粹的Windows右键菜单管理程序 项目地址: https://gitcode.com/gh_mirrors/co/ContextMenuManager Windows右键菜单作为用户与系统交互的重要…

作者头像 李华
网站建设 2026/4/3 3:08:55

嵌入式Linux系统上的Magma智能体轻量部署

嵌入式Linux系统上的Magma智能体轻量部署实战 最近在折腾一个嵌入式项目&#xff0c;需要在资源有限的设备上跑一个能“看懂”屏幕并“动手”操作的AI智能体。选来选去&#xff0c;最终锁定了微软开源的Magma模型——这家伙不仅能理解图像和文字&#xff0c;还能在数字界面里导…

作者头像 李华
网站建设 2026/4/1 16:34:19

从理论到实践:GTE文本嵌入模型在知识库检索中的应用

从理论到实践&#xff1a;GTE文本嵌入模型在知识库检索中的应用 你有没有遇到过这样的问题&#xff1a; 知识库明明存了上百页技术文档&#xff0c;用户问“如何配置GPU推理环境”&#xff0c;系统却返回了三篇讲CPU优化的旧文章&#xff1f; 或者客服知识库中&#xff0c;“退…

作者头像 李华
网站建设 2026/4/1 0:41:01

自动驾驶感知入门:PETRV2-BEV模型训练全流程

自动驾驶感知入门&#xff1a;PETRV2-BEV模型训练全流程 1. 引言&#xff1a;从鸟瞰视角看懂自动驾驶的“眼睛” 想象一下&#xff0c;你坐在一辆自动驾驶汽车里&#xff0c;它没有激光雷达&#xff0c;只靠车身上的几个摄像头&#xff0c;就能像鸟一样俯瞰整个路面&#xff…

作者头像 李华
网站建设 2026/3/22 14:31:15

DamoFD与PS软件集成:摄影后期自动化处理方案

DamoFD与PS软件集成&#xff1a;摄影后期自动化处理方案 1. 引言 作为一名摄影师&#xff0c;你是否曾经花费数小时在Photoshop中手动对齐和裁剪数百张人像照片&#xff1f;特别是在处理婚礼摄影、团体合影或商业人像时&#xff0c;这种重复性工作不仅耗时耗力&#xff0c;还…

作者头像 李华
网站建设 2026/3/31 0:32:05

Qwen3-ASR-1.7B开源ASR系统详细步骤:从拉取镜像到API服务上线全过程

Qwen3-ASR-1.7B开源ASR系统详细步骤&#xff1a;从拉取镜像到API服务上线全过程 1. 引言&#xff1a;为什么选择Qwen3-ASR-1.7B&#xff1f; 如果你正在寻找一个既强大又好用的语音识别工具&#xff0c;那么Qwen3-ASR-1.7B很可能就是你的答案。它不是一个简单的升级&#xff…

作者头像 李华