【C语言】模拟实现strncpy strncat strncmp strchr strrchr函数

//模拟实现strncpy函数

    strncpy 是 C语言的库函数之一,来自 C语言标准库,定义于 string.h,char *strncpy(char *dest, const char *src, int n),把src所指向的字符串中以src地址开始的前n个字节复制到dest所指的数组中,并返回dest。

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strncpy(char *dest, const char *src, int n)
{
	char *p = dest;
	assert(dest != NULL);
	assert(src != NULL);
	while (n && (*dest++ = *src++))
	{
		n--;
	}
	if (n > 0)
	{
		while (--n)
		{
			*dest++ = '\0';
		}	
	}
	return p;
}
int main()
{
	char arr[50] = { 0 };
	int len = strlen("hello bit");
	printf("arr = %s\n", my_strncpy(arr,"hello bit", len));
	system("pause");
	return 0;
}


//模拟实现strncat函数

    strncat()主要功能是在字符串的结尾追加n个字符。

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strncat(char *dest, const char *src, int n)
{
	char *p = dest;
	assert(dest != NULL);
	assert(src != NULL);
	while (*dest != '\0')
	{
		*dest++;
	}
	while (n&& *src)
	{
		*dest++ = *src++;
		n--;
	}
	*dest = '\0';
	return p;
}
int main()
{
	char arr[20] = "hello  ";
	int len = strlen(arr);
	char *ret = my_strncat(arr, arr, len);
	printf("%s", ret);
	system("pause");
	return 0;
}



//模拟实现strncmp函数

  int strncmp ( const char * str1, const char * str2, size_t n );
 【参数】str1, str2 为需要比较的两个字符串,n为要比较的字符的数目。
字符串大小的比较是以ASCII 码表上的顺序来决定,此顺序亦为字符的值。strncmp()首先将s1 第一个字符值减去s2 第一个字符值,若差值为0 则再继续比较下个字符,直到字符结束标志'\0',若差值不为0,则将差值返回。例如字符串"Ac"和"ba"比较则会返回字符"A"(65)和'b'(98)的差值(-33)。注意:要比较的字符包括字符串结束标志'\0',而且一旦遇到'\0'就结束比较,无论n是多少,不再继续比较后边的字符。
【返回值】若str1与str2的前n个字符相同,则返回0;若s1大于s2,则返回大于0的值;若s1 若小于s2,则返回小于0的值。


#include<stdio.h>
#include<string.h>
#include<assert.h>
int my_strncmp(const char *arr1, const char *arr2, int n)
{
	assert(arr1 && arr2);
	while (n && (*arr1 == *arr2))
	{
		if (arr1 == '\0')
			return 0;
		arr1++;
		arr2++;
		n--;
	}
	return *arr1 - *arr2;
}

int main()
{
	char *arr1 = "abcdef";
	char *arr2 = "abcde";
	int len = strlen(arr1);
	int ret = my_strncmp(arr1, arr2, len);
	printf("%d\n", ret);
	system("pause");
}



//模拟实现strrchr函数

    strrchr() 函数查找字符在指定字符串中从左面开始的最后一次出现的位置,如果成功,返回该字符以及其后面的字符,如果失败,则返回 NULL。与之相对应的是strchr()函数,它查找字符串中首次出现指定字符以及其后面的字符。

#include<stdio.h>  
#include<stdlib.h>  
#include<string.h>  
#include<assert.h>   
char*my_strrchr(char*str, char ch, int len)
{
	str = str + len - 1;
	assert(str);
	while (*str != '\0')
	{
		if (*str == ch)
			return str;
		str--;
	}
	return 0;
}
int main()
{
	int ch = 0;
	char arr[] = "abc  dab cdfgh";
	int len = strlen(arr);
	printf("请输入要查的字符");
	scanf_s("%c", &ch);
	printf("%s\n", my_strrchr(arr, ch, len));
	system("pause");
	return 0;
}



//模拟实现strchr函数

    strchr函数原型:extern char *strchr(const char *s,char c);查找字符串s中首次出现字符c的位置。

#include<stdio.h>  
#include<stdlib.h>  
#include<assert.h>  
char* my_strchr(char*str, char ch)
{
	assert(str);
	while (*str != '\0')
	{
		if (*str == ch)
			return str;
		str++;
	}
	return 0;
}
int main()
{
	char ch = 0;
	char arr[] = "abcdabcdefgh";
	printf("请输入要查的字符");
	scanf_s("%c", &ch);
	printf("%s\n", my_strchr(arr, ch));
	system("pause");
	return 0;
}

微笑 吐舌头








  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值