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

附图:
在这里插入图片描述

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

附图:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_46078890/article/details/106590857