字符串函数---strcmp()与strncmp()详解及实现

一、strcmp()与strncmp()

strcmp(s1,s2); 比较两个字符串
strncmp(s1,s2,n); 比较两个字符串的前n位

#include<iostream>
#include<assert.h>
using namespace std;
 
int main()
{
	char a[]="aaaae";
	char b[]="aaaaf";
 
	int i=strcmp(a,b);
 
	cout<<i<<endl;
 
	int j=strncmp(a,b,4);//只比较前n个字符
 
	cout<<j<<endl;
 
 
	system("pause");
	return 0;
}
  • 返回结果分析:

    • 0:表示两个字符串s1、s2相同;
    • -1:表示s1小于s2;
    • 1:表示s1大于s2;
  • 比较规则

    • 从左到右逐个字符进行比较(ASCII值),直到出现不同的字符或遇到’\0’为止。
    • 如果全部的字符相同,则认为两字符串相等,返回值为0;
    • 如果出现不同的字符,则对第一次出现不同的字符进行比较,比较方法是以s1的第一个不同的字符减去s2的第一个不同的字符,以所得差值作为返回值(大于0,则返回1,小于0则返回-1)。
  • 运行结果为 -1,0;

二、strcmp()与strncmp()的具体实现

#include<iostream>
#include<assert.h>
using namespace std;
 
int strcmp_m(const char *s1,const char *s2)
{
	assert((s1!=NULL)&&(s2!=NULL));
 
	while(*s1!='\0'&&*s2!='\0')//字符串前面部分都相同
	{
		if(*s1-*s2>0)
			return 1;
		if(*s1-*s2<0)
			return -1;
		s1++;
		s2++;
	}
	if(*s1=='\0'&&*s2!='\0')//谁先为'\0',谁就小
		return -1;
	if(*s2=='\0'&&*s1!='\0')
		return 1;
	return 0;              //同时为'\0'     
}
 
int strncmp_m(const char *s1,const char *s2,int n)
{
	assert((s1!=NULL)&&(s2!=NULL));
 
	while(*s1!='\0'&&*s2!='\0'&&n)//字符串前面部分都相同
	{
		if(*s1-*s2>0)
			return 1;
		if(*s1-*s2<0)
			return -1;
		s1++;
		s2++;
		n--;
	}
	if(*s1=='\0'&&*s2!='\0')//谁先为'\0',谁就小
		return -1;
	if(*s2=='\0'&&*s1!='\0')
		return 1;
	return 0;              //同时为'\0'  
}
 
int main()
{
	char a[]="aaaae";
	char b[]="aaaaf";
 
	int i=strcmp_m(a,b);
 
	cout<<i<<endl;
 
	int j=strncmp_m(a,b,4);//只比较前n个字符
 
	cout<<j<<endl;
 
 
	system("pause");
	return 0;
}

转载于:https://blog.csdn.net/lanzhihui_10086/article/details/39829623

猜你喜欢

转载自blog.csdn.net/weixin_41074793/article/details/88085022
今日推荐