news 2026/6/11 0:13:20

C语言递归函数的习题笔记

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言递归函数的习题笔记

字符串逆序的递归实现(C语言)

在C语言中,实现字符串逆序的递归方法是一种高效且直观的方式。递归的核心思想是将问题分解为更小的子问题:通过交换字符串的首尾字符,然后递归地处理剩余的子字符串,直到整个字符串被逆序。下面我将逐步解释算法原理,并提供完整的C语言代码实现。

递归算法原理
  1. 基本思路

    • 给定一个字符串(以null终止的字符数组),我们定义一个递归函数,接受字符串指针和两个索引参数(startend)。
    • 基本情况(base case):如果start >= end,表示子字符串已经处理完毕(只有一个字符或空),直接返回。
    • 递归步骤:交换str[start]str[end]位置的字符,然后递归调用函数处理子字符串str[start+1]str[end-1]
    • 通过递归调用,字符串会从两端向中心逐步交换字符,最终实现逆序。
  2. 时间复杂度

    • 每次递归调用处理两个字符,递归深度为字符串长度的一半。
    • 时间复杂度为 $O(n)$,其中 $n$ 是字符串长度。
C语言代码实现

以下是完整的C语言程序,包括递归函数和主函数测试。代码使用了标准库函数strlen来计算字符串长度,确保安全处理。

#include <stdio.h> #include <string.h> // 递归函数实现字符串逆序 void reverse_recursive(char *str, int start, int end) { if (start >= end) { // 基本情况:子字符串为空或只有一个字符 return; } // 交换首尾字符 char temp = str[start]; str[start] = str[end]; str[end] = temp; // 递归处理剩余子字符串 reverse_recursive(str, start + 1, end - 1); } int main() { char str[] = "hello"; // 测试字符串 int length = strlen(str); // 计算字符串长度 // 调用递归函数,起始索引0,结束索引length-1 reverse_recursive(str, 0, length - 1); printf("逆序后的字符串: %s\n", str); // 输出结果 return 0; }
代码解释
  • 递归函数reverse_recursive

    • 参数:str是指向字符串的指针,start是当前子字符串的起始索引,end是结束索引。
    • 第3行:检查基本情况,如果start >= end,则停止递归。
    • 第5-7行:交换str[start]str[end]的字符,使用临时变量temp
    • 第9行:递归调用自身,处理从start+1end-1的子字符串。
  • 主函数main

    • 第14行:定义测试字符串str(可修改为其他字符串)。
    • 第15行:使用strlen获取字符串长度。
    • 第17行:调用递归函数,起始索引为0,结束索引为length-1(字符串最后一个字符)。
    • 第18行:打印逆序后的字符串。
运行示例
  • 输入字符串:"hello"
  • 输出:"olleh"
注意事项
  • 本实现直接修改原字符串,不需要额外空间(原地操作)。
  • 确保字符串以null终止,否则可能引发错误。
  • 如果字符串为空或只有一个字符,递归会直接返回,不影响结果。
  • 您可以修改str的值来测试不同字符串,例如char str[] = "world".
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 14:10:09

League Akari:英雄联盟智能自动化助手的五大核心功能详解

League Akari&#xff1a;英雄联盟智能自动化助手的五大核心功能详解 【免费下载链接】LeagueAkari ✨兴趣使然的&#xff0c;功能全面的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/LeagueAkari Leagu…

作者头像 李华
网站建设 2026/6/10 19:09:27

理工科论文模板推荐:8大平台+免费下载工具

理工科论文模板推荐&#xff1a;8大平台免费下载工具 8大理工科论文工具速览 工具名称 核心功能 适用场景 免费程度 aibiye AI论文生成与优化 初稿创作、结构优化 部分免费 aicheck 论文查重与降重 查重、降重、AIGC检测 按字数收费 askpaper 文献智能阅读 文献综…

作者头像 李华
网站建设 2026/6/10 12:31:31

论文查重率排名:10大平台+不同阶段标准

论文查重率排名&#xff1a;10大平台不同阶段标准论文查重率排名&#xff1a;10大平台不同阶段标准查重工具核心对比速览工具名称查重准确率数据库规模特色功能适用阶段AI论文及时雨★★★★☆千万级同步降AIGC率初稿生成后学术GPT★★★☆☆百万级语法优化查重写作过程中aiche…

作者头像 李华
网站建设 2026/6/10 12:31:16

论文规范校验工具排名:10大平台+格式审核功能

论文规范校验工具排名&#xff1a;10大平台格式审核功能 核心工具对比速览 工具名称 核心功能 处理速度 适用场景 独特优势 Aibiye AI生成人工改写 20分钟 文献综述初稿 降AIGC率15% AICheck 降AIGC查重 20分钟 知网/维普检测 适配高校标准 AskPaper 学术论文优…

作者头像 李华
网站建设 2026/6/9 19:06:51

期末文献综述撰写指南:方法、结构与常见问题解析

开题报告前那两个月&#xff0c;我电脑里塞满了乱七八糟的PDF&#xff0c;参考文献格式错得千奇百怪&#xff0c;导师一句“脉络不清”打回来三次。后来才发现&#xff0c;问题不是读得不够多&#xff0c;而是工具没用对。这三个工具帮我理清了思路&#xff0c;把一堆文献变成了…

作者头像 李华
网站建设 2026/6/9 17:37:51

ViGEmBus虚拟游戏控制器驱动:终极安装与使用指南

项目简介与核心价值 【免费下载链接】ViGEmBus 项目地址: https://gitcode.com/gh_mirrors/vig/ViGEmBus ViGEmBus是一款革命性的Windows内核级驱动程序&#xff0c;专门为游戏玩家和开发者提供虚拟游戏控制器支持。通过这款驱动&#xff0c;你可以在PC上完美模拟Xbox …

作者头像 李华