字符串大小比较241
发布网友
发布时间:2023-10-26 01:25
我来回答
共5个回答
热心网友
时间:2024-11-23 20:51
如果单纯比较长度,直接调用类似于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.
热心网友
时间:2024-11-23 20:51
比大小,从头一个开始,
头一个谁大,这个字符串就是 谁大。
如果第一个一样大,比第二个。
热心网友
时间:2024-11-23 20:52
是按字典顺序来比较的,
就像查字典那样,
返回在字典中前面的那个字符串的指针
当然,是区分大小写的
热心网友
时间:2024-11-23 20:52
int
strcmp(char
*s,char
*t)
{
while(*s&&*t&&
*s==*t
)
///如果字符串s和t都没结束,并且其值相等,继续比较
s++;t++;
}
return(*s-*t);
///返回差值,如果*s大,返回正数,如果*t大,返回负数,如果相等,返回0
}
热心网友
时间:2024-11-23 20:53
另外,如果是C++语言的话,要比较字符串的大小就直接str1<str2,再return就OK了,不会像C那样麻烦的要一个字符一个字符的比较