算法思想:数组在传参的时候,str存放的是数组arr的首地址,这时我们只需要判断这个地址存放的字符是否为'\0',如果是就1+再调用函数,这时str的地址再+1,再进行判断。直到存放'\0'的地址之后,递归结束。
例如:字符串为 wer
调用函数:*str=w, 返回:1+my_strlen(str+1)
*str=e, 1+1+my_strlen(str+1)
*str=r, 1+1+1+my_strlen(str+1)
*str='\0' 1+1+1+0
代码如下:
#include<stdio.h>
int my_strlen(char *str)
{ //判断字符串的长度
if(*str != '\0')
{
return 1+my_strlen(str+1);
}
return 0;
}
int main()
{
char arr[10];
scanf("%s",arr);
int len = my_strlen(arr);
printf("len=%d\n",len);
return 0;
}