您的当前位置:首页正文

C语言-strcmp(对比函数模拟和使用)

2024-11-20 来源:个人技术集锦

strcmp(对比函数模拟和使用)

strcmp的语法

 字符串的比较目的

这里比如你写一个网站,对照自己的用户和密码进行对比

使用(对比)方式

strcmp(arr1,arr2)

常量

所以不能这样对比

而是

对比方式

如果要比较两个字符串的内容

比较逻辑 一一对应的比较

四种情况 这里比较的是内容

使用逻辑

上面的小于 返回值是-1

这里比较的对应ASCII码值的大小 遇见不一样的直接跳出循环 遇见一样但继续 一个一个进行对比 对比完进行下一个

返回数值逻辑 vs这里是-1 1 0 进行判断的 不一定一定是-1 1

 使用的代码实现

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<string.h>
int main()
{
	char arr1[] = "sadaasd";
	char arr2[] = "sadaasd";
	char arr3[] = "sadasd ";
	char arr4[] = "sadasde";
		int ret1 = strcmp(arr1, arr2);//这里需要说明一下 是一个一个对应 什么意思呢就是 ss 对照  aa dd aa。。。所以返回0
	int ret2 = strcmp(arr1, arr3);//ss aa dd aa as这里是a的ASCII码值比s小 所以返回-1 此时不进行下面的循环
	int ret3 = strcmp(arr4, arr3);
	//这里的逻辑对比是一一对比,如果 前面的字符大 此时也就返回1 小的情况下 也就返回-1 相等的情况下 也就是整个字符串相等 返回0 
	printf("%d\n%d\n%d\n\n", ret1, ret2, ret3);
	printf("%d\n%d\n%d\n\n", ret1, ret2, ret3);
}

 

 代码讲解

`strcmp` 是一个在 C 语言中常用的字符串比较函数,它的作用是比较两个字符串的内容是否相同。`strcmp` 函数的定义通常在 `<string.h>` 头文件中,其原型如下:

int strcmp(const char *str1, const char *str2);

`strcmp` 函数按照 ASCII 码的值逐个字符比较两个字符串。它的比较方式如下:
1. 从第一个字符开始比较,如果两个字符串的对应字符的 ASCII 码值相同,则继续比较下一个字符。
2. 如果两个字符串的对应字符的 ASCII 码值不同,`strcmp` 函数返回两个 ASCII 码值之间的差值的符号位,即如果第一个不同字符的 ASCII 码值在字符串1中大于字符串2中的对应字符,则返回正值;如果小于,则返回负值;如果相等,则继续比较下一个字符。
3. 如果在某个字符上比较结果不同,则函数停止比较并返回结果,不会等到字符串结束。
4. 如果两个字符串完全相同,`strcmp` 函数返回 `0`。
这里有一些例子来说明 `strcmp` 的比较方式:



// 比较 "hello" 和 "hello"
strcmp("hello", "hello") → 返回 0
// 比较 "hello" 和 "world"
strcmp("hello", "world") → 返回负值
// 比较 "hello" 和 "Hello" (注意大小写)
strcmp("hello", "Hello") → 返回负值
// 比较 "hello" 和 "hell" (较短的字符串)
strcmp("hello", "hell") → 返回正值

需要注意的是,`strcmp` 函数对比较的字符串大小写敏感。如果你需要进行不区分大小写的比较,可以使用 `strcasecmp` 函数(在 `<string.h>` 中定义)或者在 `strcmp` 函数中自己转换字符到小写或大写进行比较。
在使用 `strcmp` 函数时,应该注意比较的两个字符串都是以 `\0`(空字符)结尾的,因为如果两个字符串前缀相同,只有比较到字符串末尾或者发现一个字符不同时,`strcmp` 才会返回不同的结果。 

模拟实现(版本1)

这里加上const进行限制 防止进行修改

函数实现的逻辑 等于就继续 不等于就直接返回

在相等逻辑里面 进行判断 也就是同时遇见最后一个字符0 跳出循环

模拟实现(版本2)

不给予准确数值 返回就可以

模拟实现代码

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<string.h>
//这里采取的是两个模拟函数 也就是两个版本
int MY_strcmp(char* arr1, char* arr2)
{
	while (*arr1 == *arr2)这里代码循环的条件就是只要相等就继续++ 然后遇见最后一个字符'\0'自然会跳出循环
	{
		if (*arr1 == '\0')//遇见'\0'说明已经遇到最后一个字符了 也就可以跳出循环
			return 0;
		*arr1++; *arr2++;
	}
	return *arr1 - *arr2;//其他情况下 直接可以返回指针的差值不一定是非得是1 =1 0 这样的数值 因为每个编译器的返回数值是不一样的  我这里是vs的编译器
}
int my_strcmp(char* arr1, char* arr2)
{
	while (*arr1 == *arr2)//这里不能while(*arr1++==*arr2++)因为 这里是先++后等于 也就是 第一个元素和第二个元素的对比 所以不能这样的
	{
		if (*arr1 == '\0')//遇见'\0'说明已经遇到最后一个字符了 也就可以跳出循环
		{
			return 0;
		}
		*arr1++;//这里相等就继续++
		*arr2++;//同理
	}
	if (*arr1 > *arr2)//这里是按照*arr1也就是元素的ASCII码值进行对比的  如果大于 就返回1 小于就返回-1 不需要判断0 因为相等会继续循环
	{
		return 1;
	}
	else
	{
		return -1;
	}
}
int main()
{
	char arr1[] = "sadaasd";
	char arr2[] = "sadaasd";
	char arr3[] = "sadasd ";
	char arr4[] = "sadasde";
	int ret1 = strcmp(arr1, arr2);//这里需要说明一下 是一个一个对应 什么意思呢就是 ss 对照  aa dd aa。。。所以返回0
	int ret2 = strcmp(arr1, arr3);//ss aa dd aa as这里是a的ASCII码值比s小 所以返回-1 此时不进行下面的循环
	int ret3 = strcmp(arr4, arr3);
	//这里的逻辑对比是一一对比,如果 前面的字符大 此时也就返回1 小的情况下 也就返回-1 相等的情况下 也就是整个字符串相等 返回0 
	printf("%d\n%d\n%d\n\n", ret1, ret2, ret3);

	int ret4 = my_strcmp(arr1, arr2);
	int ret5 = my_strcmp(arr1, arr3);
	int ret6 = my_strcmp(arr4, arr3);
	printf("%d\n%d\n%d\n\n", ret4, ret5, ret6);
    //这里大家可以自己看看
	int ret7 = MY_strcmp(arr1, arr2);
	int ret8 = MY_strcmp(arr1, arr3);
	int ret9 = MY_strcmp(arr4, arr3);
	printf("%d\n%d\n%d", ret7, ret8, ret9);

}

显示全文