©作者:凡人编程传
©系列:C语言初阶(适合小白入门)
©说明:以凡人之笔墨,书写未来之大梦

文章目录

  • ₪前言
  • ₪自定义实现strlen函数(不能创建临时变量)
  • ₪结言

₪前言

这一节我们继续讲函数递归的内容,进一步深入了解递归到底是怎么做的,好了,咱们直接进入正题。

₪自定义实现strlen函数(不能创建临时变量)

可能有的人还不知道 strlen函数是啥,没关系咱们先打开MSDN查一查。

由图可知,这个函数的功能是获取一个字符串的长度。且他所属的头文件是< string.h >,返回类型是size_t(就是无符号整形),参数是const char*string,这里的const以后会讲,大家先当他不存在。好了,知道了这个函数的基本情况,不妨来使用一下。

#include<stdio.h>
#include<string.h>
int main()
{char arr[] = "bit";int len = strlen(arr);      //这里的数组名字,相当于数组首元素地址,也就是char* arrprintf("len = %d", len);return 0;
}

这里补充一点,每个字符串的都有一个结束字符’\0’,而strlen()函数刚好就是遇到这个结束字符而停止计数有多少个字符(不包括\0).

如bit这个字符串在数组中的存储如图:


运行结果:

所以strlen函数遇到\0就停止计数,那么\0之前就有3个字符,也就是3.

那么我们现在就来自己实现这个函数,咱们先不按照题目来不用创建临时变量。根据上面的情况知道,这个函数最大的特点就是遇到\0就开始不计数。那么我们是不是就可以以此来作为循环计数条件,我们把数组首元素的地址传过去,然后每次* 解引用看一看这个地址里面的元素是不是\0,如果不是就代表这个字符串至少有一个字符,那么我们的计数变量就自增记录下来这个字符串有一个字符,直到一次解引用地址里面的内容是\0代表这个字符串结束了,后面没有字符了。那么最终计数变量的长度就是字符串的长度.

代码如下:

#include<stdio.h>
int my_strlen(char* str)
{int count = 0;    //计数变量while (*str != '\0')       //如果str指针指向的地址里面的内容不是\0,那么代表字符串还没有结束{count++; //不是\0就代表是字符,记录字符个数str++;     //指针指向下一个地址}return count;
}
int main()
{char arr[] = "bit";int len = my_strlen(arr);       //这里的数组名字,相当于数组首元素地址,也就是char* arrprintf("len = %d", len);return 0;
}

运行结果:

虽然结果是正确的,但是我们不符合题意啊。题目让我们不创建临时变量。那么我们怎么改呢?唉,我们这节主要讲的是递归嘛!那肯定用递归来写啊!没错,咱们就是用递归。

咱们在回忆一下递归的两个必要条件和思想
一、 递归的两个必要条件:
1.递归一定要有限制条件
2.每次递归都越来越接近这个限制条件

二、 递归的思考方式:
把大问题,拆分成一个个与原问题类似的小问题。

其实递归两字就能体现出他的算法方式,"递"就是先到最深,“归"就是又由最深到浅,也就是从后往前面算。所以我们就可以先找到\0,让后\0开始"归”。这里要注意二点:如果我们字符串不是空串那么字符个数至少是1吧,如果字符串是空串的情况(也就是里面只有一个\0),所以写的时候一定要考虑空串的情况。那么就可以写代码了:

代码如下:

#include<stdio.h>
int my_strlen(char* str)
{if (*str != '\0')       //如果str指针指向的地址里面的内容不是\0,那么代表字符串还没有结束{return 1 + my_strlen(str + 1);       //如果地址里面的内容不是\0,那么代表至少有一个字符就是1+... ,另外我们的目的是先找到\0然后从后往前算}else{return 0;        //空串的情况}
}
int main()
{char arr[] = "bit";int len = my_strlen(arr);       //这里的数组名字,相当于数组首元素地址,也就是char* arrprintf("len = %d", len);return 0;
}

运行结果:

如果还是不懂,没关系请看看这张图:

这里还要强调二点:
1.一就是那个else情况的return 0一定要写,就算你不考虑空串的情况如果不写也会导致结果错误,因为递归"'归"的时候一定要有一个归的值,如果不写那个else返回一个0,那么编译器会自动给你返回一个随机值,那么后面1+…的时候值就会不对了。
2.二就是肯定有人会想知道那个str+1,能不能写成str++,很明确告诉你不能,因为我们想要的是当前地址的下一个地址,如果你写成str++的话那么传过去的是原来str的地址,然后传过去了str的地址再+1(后置自增,先引用,再自增),那么这就冲突了啊!

₪结言

由于时间关系,本来打算全部讲完的,但是太忙了,最后两道题我们明天补充,在这里请大家谅解,好了希望对你有收获,下一节见!

【C语言】剖析函数递归(2)相关推荐

  1. 【C语言】剖析函数递归(3)

    ©作者:凡人编程传 ©系列:C语言初阶(适合小白入门) ©说明:以凡人之笔墨,书写未来之大梦 文章目录 ₪前言 ₪求一个数的阶乘(递归实现) ₪求斐波那契数列的第n项 ₪结言 ₪前言 这一节,咱们把递 ...

  2. 计算机二级C语言考的函数,【帮考网】2012计算机等级二级考试C语言:函数递归...

    一.栈 在说函数递归的时候,顺便说一下栈的概念. 栈是一个后进先出的压入(push)和弹出(pop)式数据结构.在程序运行时,系统每次向栈中压入一个对象,然后栈指针向下移动一个位置.当系统从栈中弹出一 ...

  3. C语言使用函数递归实现n的k次方(包括负数次方)

    文章目录 前言 代码示例 实现效果 前言 题目要求:使用C语言写一个函数,能够使用函数递归实现计算n的k次方,包括负数次方. 题目分析: 要求使用递归,先求出递归公式,假设我们的函数是 myPow(i ...

  4. C语言程序设计 函数递归调用示例

    函数递归调用示例(教材习题5.3,运行结果012345) #include<stdio.h> void fun(int k); void main() {   int w=5;   fun ...

  5. 【C语言】函数递归(详解)

    文章目录 函数递归 什么是递归? 递归的俩个必要条件 代码引例1 栈溢出(Stack Overflow) 合理使用递归 代码引例3 代码引例4 解释要合理使用递归 结束语 函数递归 程序调用自身的编程 ...

  6. 【C语言】函数递归详解

    函数递归 1. 什么是函数递归 2. 递归的两个必要条件 2.1 练习1:打印一个数的每一位 2.2 练习2:求字符串长度(strlen 模拟实现) 3. 递归与迭代 3.1练习3:求 n 的阶乘(不 ...

  7. 学点 C 语言(35): 函数 - 递归

    1. 递归就是: 函数自己调用自己 这是一个最简单的递归, 不过它会一直执行, 可用 Ctrl+C 终止. #include <stdio.h>void prn(void) {printf ...

  8. [日常] Go语言圣经-函数递归习题

    练习 5.1: 修改findlinks代码中遍历n.FirstChild链表的部分,将循环调用visit,改成递归调用. 练习 5.2: 编写函数,记录在HTML树中出现的同名元素的次数. 练习 5. ...

  9. C语言_函数递归举例

    1.递归和非递归分别实现求第n个斐波那契数. //求第 n 个斐波那契数 #include <stdio.h> #include <stdlib.h>int Fib1(int ...

最新文章

  1. ASP.NET MVC之从控制器传递数据到视图四种方式(一)
  2. 电脑常见问题_电脑知识,每日一课,计算机常用维修小技巧
  3. Linux ibm mq 教程,IBM MQ 使用指南
  4. c语言中的static变量和static函数
  5. Web Essentials 2015--html
  6. 释疑の手工凭证界面不显示页数
  7. Mybatis实现CRUD操作
  8. 非管理型工业交换机和管理型工业交换机的区别和选择
  9. ubuntu 自动清理/tmp目录
  10. 视频语义显著实例分割数据集SESIV
  11. mybatis工作原理_万字好文!MyBatis 的工作原理,你了解过吗?
  12. ROS笔记(22) Gmapping
  13. 程序员给小姐姐修电脑的最佳地方和姿势
  14. mysql 变量定义和赋值_MySQL变量解析
  15. 活动丨想和大咖云风来场1对1的亲面交流吗?!快来分享你的《程序员修炼之道》学习心得!
  16. 计算机教育考试多少分及格,全国职称计算机考试多少分及格?
  17. 小项目一:使用fping统计网络中主机的网络连通情况
  18. Julia语法归纳总结
  19. 如何防止iOS工程师简历石沉大海的几大秘技(请注意查收)
  20. 作为程序员的你,这10款在线编辑器,你用过哪一个?

热门文章

  1. html5新年网页做给父母的,把孝心献给父母
  2. 【unity 保卫星城】--- 开发笔记(Demo演示篇)
  3. 《30而已》烂尾,如果这样卖空山茶,顾佳会逆袭
  4. PHP 使用TCPDF插件生成pdf以及pdf的中文处理
  5. DaoCloud Enterprise 5.0社区版永久免费!支持免费下载使用、学习和测试,体验企业级云原生底座的性能
  6. 解决方案产品化?如何执行
  7. 定时执行mysql数据库任务方案
  8. 经典游戏打砖块(粗糙版)
  9. DICOM医学影像协议
  10. Web应用程序,简单的日志系统解决方案