字符串排序思路,或者叫做两个字符串比较大小

字符串对象本质上是字符数组。字符串的排序归结为其对应的字符数组的排序(不是数组内部排序,而是数组之间的比较和排序)。
而字符都有对应的码值,单就英文字母a~z来说,各个字母对应码值相对是升序的,即a的码值小于b的码值,依次往后增大。因为每个字符都有一一对应且唯一的码值,这就为比较乃至排序提供了基础。
可按如下思路对两个字符串排序。
1.如两串对应的字符数组长度相等,从数组下标为0开始开始比较码值,如果相等,下标加一,继续向后比较,直到出现码值不等时,结束比较。若是升序,则(码值较小的字符→所在的字符数组→此数组对应的字符串)排在前面,另外一个排在后面;降序则反之。
如abd, abc升序排序后为abc, abd。
2.若字符串对应长度不相等,则取两串中较小的长度作为比较的最大轮次,此时比较和情况1一样。若比完最大轮次对应数组相同下标对应的码值都相同,则串长的排在后面(假如升序)。
如abcdefg, abcd按升序排序后为abcd, abcdefg。

以下代码是java.lang.String的compareTo方法源码:

  public int compareTo(String anotherString) {
        int len1 = value.length;
        int len2 = anotherString.value.length;
        int lim = Math.min(len1, len2);
        char v1[] = value;
        char v2[] = anotherString.value;

        int k = 0;
        while (k < lim) {
            char c1 = v1[k];
            char c2 = v2[k];
            if (c1 != c2) {
                return c1 - c2;
            }
            k++;
        }
        return len1 - len2;
    }
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 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
发出的红包

打赏作者

bitDesigner

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值