模拟实现strcmp

模拟实现strcmp

概述


对两个字符串自左至右逐个字符相比较,直到出现不同的字符或遇到’\0’
注意:比较字符的大小(按ASCII码值大小比较)
解题思路:
1> 判断出较长的一个字符串,作为for循环的条件,然后才能比较;
2> 直接比较一个字符的大小即可判断出整个字符串的大小,大于返回-1,小于返回0,若字符串没有遇到’\0’,出现字符相等则跳出本次循环,比较下一个字符;
3> 返回结果并打印。

代码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
 
//模拟实现strcmp
 
int Cmp(const char* arr1, const char* arr2)
{
	int i = 0;
	int len = 0;
	size_t len1 = strlen(arr1);
	size_t len2 = strlen(arr2);
	//判断哪个字符串长,使用长的做for循环条件
	if (len1 >= len2)
	{
		len = len1;
	}
	else
	{
		len = len2;
	}
	for (i = 0; i <= len; i++)
	{
		//若果两个字符相等,并且不为'\0',跳出本次循环
		if ((arr1[i] == arr2[i]) && (arr1[i] != '\0'))
      {
			continue;
		}
		//如果目标字符串arr2小于源字符串arr1返回-1
		if (arr1[i] < arr2[i])
		{
			return -1;
		}
		//如果同时到达'\0',表示两个字符串相等
		if ((arr1[i] == '\0') && (arr2[i] == '\0'))
		{
			return 0;
		}
		//如果目标字符串arr2da于源字符串arr1跳出循环,返回1
		else
		{
			break;
		}			
	}
	return 1;
}
int main()
{
	char arr1[] = "hello world";
	char arr2[] = "hello";
	printf("%d\n", Cmp(arr1, arr2));
	system("pause");
	return 0;
}
 

运行结果:

在这里插入图片描述

另一种方法:

简单说明思路:这种方法简单好理解,采用指针变量对字符串数组的字符一一比较,直到遇到’\0’,跳出while循环,在后面再判断此时字符的大小。

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
 
//5.实现strcmp
 
char Mystrcmp(const char* dest, const char* src)
{
	while ((*dest != '\0') && (*src != '\0'))
	{
		if (*dest < *src)
		{
			return -1;
		}
		else if (*dest>*src)
		{
			return 1;
		}
		else
		{
			++dest;
			++src;
		}
	}
	if (*dest < *src)
	{
		return -1;
	}
	else if (*dest>*src)
	{
		return 1;
	}
	return 0;
}
 
int main()
{
	char dest[] = "hello world";
	char src[] = "hello";
	int ret = Mystrcmp(dest, src);
	printf("%d\n", ret);
	system("pause");
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值