字符串大小比较

2024-11-22 20:06:21
推荐回答(5个)
回答1:

如果单纯比较长度,直接调用类似于strlen()之类的函数就可以,加以比较即可.

如果比较字符串的大小,则比较的是字符的ASCII编码的大小.你搜索一下ASCII码表就可以得知每一个ASCII字符的大小. 参考http://www.wpyz.net/noip/11-1.asp

在比较时,设置一个计数器,从零开始,一直循环到最短的那个字符结束,一位一位进行比较,

1.如果 字符串1的第n位的ASCII码值 等于 字符串2的第n位的ASCII码值
则 继续比较下一位
2.如果 字符串1的第n位的ASCII码值 大于 字符串2的第n位的ASCII码值
则 输出结果:1,表示字符串1 > 字符串2;
3.如果 字符串1的第n位的ASCII码值 小于 字符串2的第n位的ASCII码值
则 输出结果:-1 表示字符串1 < 字符串2;
4.如果 每一位的ASCII码值都相等,而且长度相同,
则 输出结果:0 表示字符串1 == 字符串2;
5.如果 字符串1是字符串2的前m位,例如 abcd 与abcdef 比较,
则 字符串1<字符串2.
原因是,到第5位时,字符串1的ASCII值是0,而字符串2的ASCII值为'e',即十进制的101,当然是字符串2大了.

具体到 cds和lesoqd

从第一位开始,'c'和'l'比较,当然是'c' < 'l'了,所以,"cds" < "lesoqd"
常用的几位ascii的顺序从小到大为:

0..9, A..Z, a..z.

回答2:

比大小,从头一个开始,
头一个谁大,这个字符串就是 谁大。

如果第一个一样大,比第二个。

回答3:

是按字典顺序来比较的,
就像查字典那样,

返回在字典中前面的那个字符串的指针

当然,是区分大小写的

回答4:

int
strcmp(char
*s,char
*t)
{
while(*s&&*t&&
*s==*t
)
///如果字符串s和t都没结束,并且其值相等,继续比较
s++;t++;
}
return(*s-*t);
///返回差值,如果*s大,返回正数,如果*t大,返回负数,如果相等,返回0
}

回答5:

另外,如果是C++语言的话,要比较字符串的大小就直接str1