strlen是一个库函数,是专门求字符串长度的,只能针对字符串,从参数给定地址向后一直找“\0”,
统计“\0”之前出现的字符的个数。
现给字符串“abcd”,要求写一个计算此字符串长度的函数
#include <stdio.h>
int my_strlen(char arr[]); // 函数声明
int main()
{
char arr[] = "abcd";
int len = my_strlen(arr);
printf("%d\n", len);
return 0;
}
// first: 遍历数组,count计数,if判停止
int my_strlen(char arr[])
{
int i = 0;
int count = 0;
while (1)
{
if (arr[i] != '\0')
{
count++;
i++;
}
else
break;
}
return count;
}
如果你对数组名和指针有足够理解,那么此代码还可优化
#include <stdio.h>
int my_strlen(char arr[]); // 函数声明
int main()
{
char arr[] = "abcd";
int len = my_strlen(arr);
printf("%d\n", len);
return 0;
}
// second: 遍历数组,count计数,if判停止
int my_strlen(char arr[]) //数组名就是数组首元素地址
{
int count = 0;
while (*arr != '\0')
{
count++;
arr++;
}
return count;
}

如果你对递归算法有一定理解,那么事情就更简单了
#include <stdio.h>
int my_strlen(char arr[]); // 函数声明
int main()
{
char arr[] = "abcd";
int len = my_strlen(arr);
printf("%d\n", len);
return 0;
}
// third: 递归
int my_strlen(char arr[]) //数组名就是数组首元素地址相当于 char*str
{
if (*arr != '\0')
return 1 + my_strlen(arr + 1);
else
return 0;
}

递归过程大致如下:

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了