非递归实现:
1.计数器法
#include<stdio.h>
#include<windows.h>
int MyStrlen(char* str)
{
//模拟实现strlen函数
int count = 0;//定义一个计数器
while (*str != '\0')
{
count++;
str++;
}
return count;
}
int main()
{
char arr[] = "abcd1235";
printf("%d\n", MyStrlen(arr));
system("pause");
return 0;
}
//运行环境:vs2019
附图:
2.指针相减法
#include<stdio.h>
#include<windows.h>
int Mystrlen( const char* arr)
{
const char* start = arr;//头指针
const char* end = arr;//尾指针
while (*end != '\0')
{
end++;
}
return end - start;//两指针相减就是经历的元素个数
}
int main()
{
const char arr[] = "abcd1234";
printf("%d\n", Mystrlen(arr));
system("pause");
return 0;
}
//运行环境:vs2019
附图:
递归实现:
#include<stdio.h>
#include<windows.h>
int MyStrlen(char* str)
{
//模拟实现strlen函数
if(*str == '\0')
{
return 0;
}
return 1 + MyStrlen(str + 1);
}
int main()
{
char arr[] = "abcd1235";
printf("%d\n", MyStrlen(arr));
system("pause");
return 0;
}
//环境运行:vs2019
附图: