用c语言实现strncmp,strncat,memset, memcmp

1.int strncmp ( char * str1, char * str2, size_t num)
用法:#include <string.h>
功能: 比较字符串str1和str2的前n个字符.
返回结果:如果前n字节完全相等,返回值就=0;在前n字节比较过程中,如果出现str1[n]与str2[n]不等,则返回(str1[n]-str2[n])
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
int strncmp(const char * str1, const char * str2, size_t num)
{
	assert(str1);
	assert(str2);
	//在接下来的while函数中
	//第一个循环条件:--num,如果比较到前num个字符则退出循环
	//第二个循环条件:*str1 == *str2,如果两字符比较不等则退出循环
		while (--num&&*str1 == *str2)
		{
			if (*str1== '\0')//*str1,如果str1指向的字符串末尾退出循环
				return 1;
			else 
			str1++;//str1指针自加1,指向下一个字符
			str2++;//str2指针自加1,指向下一个字符
		}

		return *str1 - *str2;//返回比较结果
}
int main()
{
	char *arr1 = "aaabbb", *arr2 = "aaaccc";
	int m = 0;
	printf("输入要比较的个数:");
	scanf("%d", &m);
	int ret=strncmp(arr1, arr2, m);
	if (ret == 1)
	{
			printf("两个字符串相同!\n");
	
	}
	else
	{
			printf("两个字符串差值为:%d\n", ret);
	
	}
	system("pause");
	return 0;
}

2.char *strncat(char * s1,const char * s2.size_t n);
s2字符串中只有前n个字符被追加到s1字符串,复制过来的s2字符串的第一个字符覆盖了
s1字符串结尾的空字符。s2字符串中包括s2[n]在内的字符都不会被复制,并且追加
一个空字符到所得结果后面。返回值是s1。
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
char *strncat(char  *dest, char const *src,size_t  n)
{ 
	assert(dest);
	assert(src);
	char *temp = dest;
	while (*dest)
	{
		dest++;
	}
	while (n-- && *src)
	{
		*dest++ = *src++;
	}
	*dest = '\0';
	return temp;

}
int main()
{
	char arr[50] = "i come from china!!";
		char *p = " me too!!";
		int m = 0;
		printf("输入要追加的个数:");
		scanf("%d", &m);
		strncat(arr, p,m);
		printf("%s\n", arr);
		system("pause");
	   return 0;
}

3.void *memset(void *s, int ch, size_t n);
函数解释:将s中前n个字节 (typedef unsigned int size_t )用 ch 替换并返回 s 。
memset:作用是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法[1]  。
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<string.h>
void *my_memset(void *s, int ch, size_t n)
{
	assert(s);
	void *temp = s;
	while (n--)
	{
		*(char *)s= (char)ch;
		s = (char *)s+1;
	}
	return temp;

}
int main()
{
	char arr[] = "abcdefg";
	int m = 0;
	printf("输入要初始化的内容:");
	scanf("%s", &m);
    my_memset(arr,m,strlen(arr));
	puts(arr);
	system("pause");
	return 0;
}
4.int memcmp(const void *buf1, const void *buf2, unsigned int count);
比较内存区域buf1和buf2的前count个字节。
该函数是按字节比较的。
#include<stdio.h>
#include<stdlib.h>
int my_memcmp(const void *s1, const void *s2, size_t n)
{
	char *arr1 = (char *)s1;
	char *arr2 = (char *)s2;
	while (--n&&*arr1&&*arr1 == *arr2)
	{
		arr1++;
		arr2++;
	}
	return *arr1 - *arr2;
}
int main()
{
	char *p = "abcdef";
	char *q = "abcdef";
	int r;
	r=my_memcmp(p, q, 3);
	if (r == 0)
	{
		printf("两个字符串相等!\n");
	}
	else if (r < 0)
	{
		printf("字符串p小于字符串q!\n");
	}
	else
		printf("字符串p大于字符串q!\n");
	system("pause");
	return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值