两个字符串的比较

算法描述:编写一个函数,实现两个字符串的比较,即自己写一个strcmp函数,函数原型为

int strcmp(char *p1, char *p2);

设p1指向字符串s1,p2指向字符串s2。要求当s1= s2时,返回值为0;若s1 != s2,返回他们二者第一个不同字符的ASCII码差值(如“BOY”与“BAD”,第二个字母不同,“O”与“A”之差为79 - 65 = 14)。如果s1 > s2,则输出正值;如果s1 < s2,则输出负值。



#include <stdio.h>

int strcmp(char *p1, char *p2)
{
	int i = 0;
	while(*(p1 + i) == *(p2 + i))
		if (*(p1 + i++) == '\0')//++的优先级大于+
			return 0;
	return *(p1 + i) - *(p2 + i);
}

int main()
{
	int m;
	char str1[20], str2[20], *p1, *p2;
	printf("input two strings:\n");
	scanf("%s",str1);//scanf()在输入数据时,遇空格或按enter或tab键,结束该数据输入
	scanf("%s",str2);
	p1 = str1;
	p2 = str2;
	m = strcmp(p1, p2);
	printf("result:%d\n",m);
	return 0;
}


### 回答1: 字符串的大小比较涉及到字符串的字符编码和字符顺序,可以使用字符串比较运算符进行比较。在大多数编程语言中,字符串比较运算符都返回一个整数值,表示两个字符串的大小关系。具体来说,如果字符串1小于字符串2,则返回负整数;如果字符串1等于字符串2,则返回0;如果字符串1大于字符串2,则返回正整数。下面是一个示例代码(使用Python): ``` str1 = "abc" str2 = "def" result = str1.compare(str2) if result < 0: print("str1 < str2") elif result == 0: print("str1 = str2") else: print("str1 > str2") ``` 在这个示例中,我们比较字符串"abc"和"def"的大小关系,输出结果为"str1 < str2",表示字符串"abc"小于字符串"def"。 ### 回答2: 比较两个字符串的大小是通过比较它们的字典序来确定的。字典序是指从左到右按照字符的ASCII码值逐个比较,直到找到不同的字符为止。 在比较过程中,如果某个字符串的当前字符的ASCII码值小于另一个字符串的当前字符的ASCII码值,则这个字符串较小;反之,如果当前字符的ASCII码值大于另一个字符串的当前字符的ASCII码值,则这个字符串较大。当两个字符串的当前字符的ASCII码值相等时,需要比较一个字符,直至找到不同字符或者其中一个字符串的所有字符都比较完为止。 需要注意的是,比较大小的字符串是以字符为单位进行比较,而不是整个字符串。而对于空字符串比较,通常认为空字符串是任意一个非空字符串的前缀,即为空字符串较小。 比较字符串大小的结果有三种可能的情况:如果一个字符串是另一个字符串的前缀,则较短的字符串较小;如果两个字符串具有相同的前缀,但是一个字符串更长,则较长的字符串较大;如果两个字符串在某个字符位置出现不同,则根据这个字符的ASCII码值来判断较小或较大的字符串。 综上所述,比较两个字符串的大小就是通过逐个字符的ASCII码值比较来确定的,直到找到不同的字符或其中一个字符串的所有字符都比较完为止。 ### 回答3: 比较两个字符串的大小需要根据字符的ASCII码值进行比较比较的方式是从左到右逐个字符比较,直到找到不相等的字符为止。 如果两个字符串的长度不相等,那么较长的字符串大于较短的字符串。 如果两个字符串的长度相等,那么逐个字符比较它们的ASCII码值。比较的规则是从第一个字符开始比较,如果两个字符的ASCII码值相等,则比较一个字符,直到找到不相等的字符。如果找到不相等的字符时,第一个字符串的字符的ASCII码值大于第二个字符串的字符的ASCII码值,那么第一个字符串大于第二个字符串;反之,如果第一个字符串的字符的ASCII码值小于第二个字符串的字符的ASCII码值,那么第一个字符串小于第二个字符串。 如果遍历完两个字符串都没有找到不相等的字符,那么这两个字符串相等。 综上所述,比较两个字符串的大小即根据ASCII码值逐个字符比较它们的大小,直到找到不相等的字符或者遍历完字符串为止。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值