strcmp函数的使用和模拟实现

8330887d86a845659e92dc18002dacca.png

目录

1.头文件

 2.strcmp函数的使用 

3.模拟strcmp函数实现  


小心!VS2022不可直接接触,否则!没这个必要,方源面色淡然一把抓住!顷刻炼化! 


1.头文件

strcmp函数的使用需要头文件

#include<string.h>

 2.strcmp函数的使用 

 bf4f660077d944e1a40c1034acbcaaf5.png

strcmp函数接收的是两个char型地址,strcmp函数会顺着这两个char型地址 ,顺藤摸瓜出整个字符串,一个一个的将每一个字符进行比较

简述:strcmp函数用于比较两个字符串大小

如果目标字符串 > 源字符串,则会返回大于0的值

如果目标字符串 = 源字符串,则会返回0

如果目标字符串 < 源字符串,则会返回小于0的值

示例如下:

#define _CRT_SECURE_NO_WARNINGS 
#include<stdio.h>
#include<string.h>
int main()
{
	char arr1[] = { "abc" };
	char arr2[] = { "agc" };
	int ret = strcmp(arr1, arr2);
	printf("%d ", ret);
	//abc < abg,打印小于0的数
}

在字符串比大小中,a<b<c<d<....,越靠后的字母越大

如果是大写比小写,一定是小写大,a > A

这是因为字符比较的是ASCII 值的大小,因为 a - 32 = A,所以小写大


3.模拟strcmp函数实现 

想要模拟strcmp函数实现,只需要一个一个判断字符大小即可,最终返回一个整数

那么,代码如下:

#define _CRT_SECURE_NO_WARNINGS 
#include<stdio.h>
int my_strcmp(char* arr1,char* arr2) {
	while (*arr1 == *arr2) {
		if (*arr1 == '\0') {
			return 0;
		}
		arr1++;
		arr2++;
	}
	return *arr1 - *arr2;
}
int main()
{
	char arr1[] = { "abcd" };
	char arr2[] = { "abc" };
	int ret = my_strcmp(arr1,arr2);
	printf("%d ", ret);
}

因为字符相减得到的整数是它们的ascII值,利用这一点可以实现 return *arr1 - *arr2,如果arr1大那就会得到相减后的ascII值,那一定是正数,反之则是负数

8fdd48caf53e46a897fd8a5554dbb454.png

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值