首先不用递归,用创建临时变量的方法来实现模拟strlen。
#include <stdio.h>
int moni_strlen(char str[])
{
int count = 0;
while (*str != '\0')
{
count++;
str++; //str是指针变量,str++跳转到下一个元素,*str取出str指向元素的值。
}
return count;
}
int main()
{
char arr[20] = { 0 };
scanf("%s", arr);
int len = moni_strlen(arr);
printf("%d\n", len);
return 0;
str++之后,*str指向下一个数组元素。
不创建临时变量,可以使用函数递归的方法,来模拟strlen。
#include <stdio.h>
int moni_strlen(char str[])//这里代入的是数组首元素的地址
{
if (*str != '\0')
{
return 1 + moni_strlen(str + 1);//函数的递归,字符数的计算值增加的同时,将下一个数组元素的地址再代人函数,直到遇到\0
}
else
{
return 0;
}
}
int main()
{
char arr[20] = { 0 };
scanf("%s", arr);
int len = moni_strlen(arr);
printf("%d\n", len);
return 0;
}
moni_strlen每运作一次return值加一,并且*str变为下一个元素,直到遇到\0
最终len的值就是字符的长度。