C语言模拟实现库函数strlen(递归和非递归实现)

非递归实现:

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

附图:
C语言模拟实现库函数strlen(递归和非递归实现)_第1张图片

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

附图:
C语言模拟实现库函数strlen(递归和非递归实现)_第2张图片

递归实现:

#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

附图:
C语言模拟实现库函数strlen(递归和非递归实现)_第3张图片

你可能感兴趣的:(C语言模拟实现库函数strlen(递归和非递归实现))