进阶版求字符串长度

大家好呀!!!我是Beilef,一个努力的跨界者,今天带来的每日一题是用简单的函数还有递归求字符串长度。下面开始啦,不对的地方请留言。感谢您的斧正。

 

文章目录

  • 目录

    文章目录

    前言

    一、题目展示

     解题思路:

    递归是⼀种通过反复调⽤⾃⾝来解决问题的⽅法。在递归函数中,函数会调⽤⾃⼰,并在每次调⽤中 传⼊不同的参数,直到达到某个基准条件,然后递归结束并返回结果。递归可以让⼀些复杂的问题更 容易理解和解决。 在编写递归函数时,需要考虑以下⼏个要素: 1. 递归结束条件:递归必须有⼀个结束条件,否则会导致⽆限递归,最终导致堆栈溢出等问题。 2. 递归调⽤:在递归函数中必须调⽤⾃⾝。 3. 递归传参:递归函数每次调⽤⾃⾝时,需要传⼊不同的参数,以处理不同的情况。 本题我们可以利⽤递归解决,递归函数的实现步骤如下: 1. 递归结束条件:字符串指针指向空字符; 2. 递归调⽤:字符串的⻓度=1+后⾯⼦字符串的⻓度; 3. 递归传参:当前字符串指针后移的结果。 通过不断调⽤递归函数,我们最终可以得到字符串的⻓度。

    二、代码演示

    2.编译结果

    总结



前言

我在前面讲过基本的求字符串的长度,这里进阶版有亿丢丢不一样


提示:以下是本篇文章正文内容,下面案例可供参考

一、题目展示

题⽬描述: 写⼀个函数Strlen,可以求字符串⻓度,除了函数的形参,函数中不能使⽤多余的变量。 输⼊⼀个字符串(字符串⻓度⼩于等于30,中间不包含空格),使⽤Strlen函数可以求字符串的⻓ 度,并返回。 注:字符串的结束标志是 \0

 解题思路:

递归是⼀种通过反复调⽤⾃⾝来解决问题的⽅法。在递归函数中,函数会调⽤⾃⼰,并在每次调⽤中 传⼊不同的参数,直到达到某个基准条件,然后递归结束并返回结果。递归可以让⼀些复杂的问题更 容易理解和解决。 在编写递归函数时,需要考虑以下⼏个要素: 1. 递归结束条件:递归必须有⼀个结束条件,否则会导致⽆限递归,最终导致堆栈溢出等问题。 2. 递归调⽤:在递归函数中必须调⽤⾃⾝。 3. 递归传参:递归函数每次调⽤⾃⾝时,需要传⼊不同的参数,以处理不同的情况。 本题我们可以利⽤递归解决,递归函数的实现步骤如下: 1. 递归结束条件:字符串指针指向空字符; 2. 递归调⽤:字符串的⻓度=1+后⾯⼦字符串的⻓度; 3. 递归传参:当前字符串指针后移的结果。 通过不断调⽤递归函数,我们最终可以得到字符串的⻓度。

 

二、代码演示

#define _CRT_SECURE_NO_WARNINGS//VS中避免类似scanf出错的方法
#include <stdio.h>
char Strlen(const char * str )//
{if(*str=='\0'){return 0;}return 1+ Strlen(str+1) ;
}
int main()
{char arr[30] = { 0 };printf("请输入你的字符串");scanf("%s", arr);int len = Strlen(arr);printf("%d", len);return 0;
}

2.编译结果


总结

今天的题目就分享到这里了谢谢大家的观看。不对的地方请多多包含(记得在评论区留言,O(∩_∩)O)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/305476.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

redis容灾的方案设计

背景 今年各个大厂的机房事故频繁&#xff0c;其中关键组件Redis是重灾区&#xff0c;本文就来看下怎么做Redis的多机房容灾 Redis多机房容灾方案 1.首先最最直观的是直接利用Redis内部的主从数据同步来进行灾备&#xff0c;但是由于Redis内部的主从实现对机房间的网络延迟等…

MySQL 8.0 InnoDB Tablespaces之General Tablespaces(通用表空间/一般表空间)

文章目录 MySQL 8.0 InnoDB Tablespaces之General Tablespaces&#xff08;通用表空间/一般表空间&#xff09;General tablespaces&#xff08;通用表空间/一般表空间&#xff09;通用表空间的功能通用表空间的限制 创建通用表空间&#xff08;一般表空间&#xff09;创建语法…

融汇贯通 —— 2023年技术与心灵的双重成长旅程

当我们站在2023年的岁末&#xff0c;回望这一年赋予我们的经历和挑战&#xff0c;心中涌动的感慨与启示像朝日初升的光芒&#xff0c;照亮脚下的路&#xff0c;亦照见心中的路。在此&#xff0c;我想分享几个方面的感悟和成长&#xff0c;愿它们能有所触动&#xff0c;成为您前…

前端---vscode 的基本使用

1. vscode 的基本介绍 全拼是 Visual Studio Code (简称 VS Code) 是由微软研发的一款免费、开源的跨平台代码编辑器&#xff0c;目前是前端(网页)开发使用最多的一款软件开发工具。 2. vscode 的安装 下载网址: Download Visual Studio Code - Mac, Linux, Windows选择对应…

laravel api资源的问题记录

resource 转换层 可以帮助我们转换一些字段的结果&#xff0c;类似前端的filter。 可以使用比如对象或者模型的形式来处理&#xff0c;但使用sql查询会导致n1的问题。如图&#xff1a; 层次嵌套很多&#xff0c;而且很深&#xff0c;这样虽然开发方便了&#xff0c;但是维护就…

FTP原理与配置

FTP是用来传送文件的协议。使用FTP实现远程文件传输的同时&#xff0c;还可以保证数据传输的可靠性和高效性。 FTP的应用 FTP 提供了一种在服务器和客户机之间上传和下载文件的有效方式。在企业网络中部署一台FTP服务器&#xff0c;将网络设备配置为FTP客户端&#xff0c;则可…

如何学习TS?

文章目录 一. 8种内置基础类型.ts二. void、never、any、unknown类型void类型never类型any类型unknown类型总结&#xff1a;void和any在项目中是比较常见的&#xff0c;never和unknown不常用。 三. 数组和函数类型定义.ts 一. 8种内置基础类型.ts /* eslint-disable typescrip…

学习笔记12——Spring的注解配置

学习笔记系列开头惯例发布一些寻亲消息 链接&#xff1a;https://baobeihuijia.com/bbhj/contents/3/192486.html SSM框架——注解配置&#xff08;Component Autowired 加载SpringConfig&#xff09; 注解开发&#xff08;Component注解、config扫描 加载SpringConfig&a…

像美团一样商家入驻的小程序功能

美团一样的商家入驻小程序可以促进本地化商家的线上线下融合&#xff0c;为本地商家和用户提供更好的服务和体验&#xff0c;是一种数字化转型和创新&#xff0c;想要开发像美团一样的商家入驻小程序&#xff0c;需要具备以下功能&#xff1a; 1、不同行业独立频道 为本地化的…

【kubernetes】集群网络(一):基础篇

Flannel 1 路由表 & arp & fdb 1.1 路由表 任何网络设备都需要路由表&#xff0c;路由表用来决定&#xff0c;当收到数据包时&#xff0c;该向哪里进行转发。路由表项通常会包含以下几个字段&#xff1a; Destination&#xff1a;目的地Gateway&#xff1a;网关Mas…

深度解析TB用户购物行为:系统搭建与优化

深度解析TB用户购物行为&#xff1a;系统搭建与优化 引言系统搭建数据集技术选型 系统功能1. 用户维度分析2. 产品维度分析3. 聚类结果分析 创新点系统优化与展望优化展望 结语 引言 在电商时代&#xff0c;了解用户购物行为并从中提取有价值的信息对于企业制定营销策略和优化…

自动化测试与功能测试的区别(超详细总结)

什么是自动化测试? 自动化测试是指利用软件测试工具自动实现全部或部分测试&#xff0c;它是软件测试的一个重要组成 部分&#xff0c;能完成许多手工测试无法实现或难以实现的测试。能够正确、合理地实施自动测试&#xff0c;可以 快速、全面地对软件进行测试&#xff0c;从…