当前位置: 首页 > news >正文

自己写计算字符串长度的函数--3种写法(C语言)

1.直接count++,直到遇到'\0'

int my_strlen1(char* p){int count = 0;while(*p != '\0'){count++;p++;}return count;  
}

2.用递归的方法

递归的两个必要条件是

  1. 有终止条件
  2. 每次调用自己后都越来越接近终止条件(列出一个公式)

想一下终止条件,字符串长度计算终止条件不就是遇到'\0'吗

那么当*p == '\0'时,递归终止;

想一下怎么构造公式。例如char* p = "abc" ,长度可以写成1+mystrlen2("ab"),即1+my_strlen2(p+1),这样一次递归指针就向后移动一次,直到遇到\0,递归终止。

int my_strlen2(char* p)
{if(*p == '\0')return 0;elsereturn 1 + my_strlen2(p + 1);
}

3.用指针-指针的方法

先看一下指针 - 指针的意义是什么。

|指针-指针| 得到的是指针和指针之间元素的个数。

例如:

int main()
{int arr[10] = { 0 };int b = &arr[9] - &arr[0];  printf("%d\n", b); //输出9,    实际上&arr[0] - &arr[9]得到的也是9return 0;
}

那么可以得到指向字符串尾元素的指针和指向首元素指针,相减就是字符串长度

int my_strlen3(char* p)
{char* start = p;//先把首元素的指针记录下来while(*p != '\0'){p++;}return p - start;}


http://www.mrgr.cn/news/44451.html

相关文章:

  • 实战OpenCV之模板匹配
  • 性能测试知识点
  • 【大语言模型-论文精读】谷歌-BERT:用于语言理解的预训练深度双向Transformers
  • FredNormer: 非平稳时间序列预测的频域正则化方法
  • Java之String类
  • 论文阅读笔记-Are Pre-trained Convolutions Better than Pre-trained Transformers?
  • node版本管理nvm详细教程
  • Qt-QTabWidget容器类控件(40)
  • 如何在 Redis 中管理副本和客户端??
  • Stable Diffusion绘画 | IP角色多视图生成技巧
  • C++:模板初阶
  • 国外电商系统开发-运维系统文件上传
  • java注解的处理器
  • 第6篇:三大渗透测试框架权限维持技术
  • 轻松部署大模型:Titan Takeoff入门指南
  • [CKA]十五、添加 Sidecar 容器并输出⽇志
  • Spring Boot驱动的现代医院管理系统
  • 怎么成为年薪53万的AI产品经理?我分析了200份大厂的招聘要求
  • js 字符串下划线转驼峰 驼峰转下划线
  • Polars的Functions