1.计数器法
int my_strlen(char str[])
{
int count=0;
while (*str != '\0')
{
count++;
str++;
}
return count;
}
int main()
{
char arr[] = {0};
gets(arr);
printf("%d", my_strlen(arr));
return 0;
}
2.递归法
int my_strlen(char str[])
{
if (*str != '\0')
{
return 1 + my_strlen(str + 1);
}
else
{
return 0;
}
}
int main()
{
char arr[] = {0};
gets(arr);
printf("%d", my_strlen(arr));
return 0;
}
3.指针相减法
int my_strlen(char* arr)
{
char* start = arr;
char* end = arr;
while (*end != '\0')
{
end++;
}
return end - start;
}
int main()
{
char arr[] = {0};
gets(arr);
printf("%d", my_strlen(arr));
return 0;
}