您的位置:

字符串排序Java

一、字符串排序

在Java中,对字符串进行排序可以使用Arrays.sort()方法,该方法可以按照字符串的字典序排序。


String[] arr = {"apple", "banana", "pear", "orange"};
Arrays.sort(arr);
System.out.println(Arrays.toString(arr));

以上代码将输出:[apple, banana, orange, pear]。

二、字符串内部排序问号位置不变

在某些情况下,需要对字符串进行内部排序,但保持字符串中问号的位置不变。

以下是一个示例代码:


String str = "ba?na?na";
char[] arr = str.toCharArray();
Arrays.sort(arr, new Comparator<Character>() {
    public int compare(Character c1, Character c2) {
        if(c1 == c2 || c1 == '?' || c2 == '?') {
            return 0;
        } else {
            return c1 - c2;
        }
    }
});

StringBuilder sb = new StringBuilder();
int qIndex = 0;
for(char c : arr) {
    if(c == '?') {
        sb.insert(qIndex++, '?');
    } else {
        sb.append(c);
    }
}
System.out.println(sb.toString());

以上代码将输出:baaa?nn?。

三、字符串排序Python

在Python中,对字符串排序可以使用sorted()函数,该函数可以按照字符串的字典序排序。

以下是一个示例代码:


arr = ["apple", "banana", "pear", "orange"]
arr = sorted(arr)
print(arr)

以上代码将输出:['apple', 'banana', 'orange', 'pear']。

四、字符串字典序排序规则

在Java中,按照字典序排序是使用compareTo()方法进行比较的。该方法返回值为0表示两个字符串相等,返回值小于0表示当前字符串小于参数字符串,返回值大于0表示当前字符串大于参数字符串。

以下是一个示例代码:


String str1 = "apple";
String str2 = "banana";
System.out.println(str1.compareTo(str2));

以上代码将输出:-1。

五、字符串排序函数

除了使用Arrays.sort()方法以外,还可以使用Collections.sort()方法对字符串进行排序。但需要将字符串转换为List类型。

以下是一个示例代码:


List<String> list = Arrays.asList("apple", "banana", "pear", "orange");
Collections.sort(list);
System.out.println(list);

以上代码将输出:[apple, banana, orange, pear]。

六、字符串排序pta

在PAT(Programming Ability Test)中,对字符串进行排序时需要注意的是,题目中已经规定了排序规则,需要按照题目要求完成。

以下是一个示例代码:


String[] strArr = {"A103 abc", "B102 abc", "A001 abc", "A100 abc"};
Arrays.sort(strArr, new Comparator<String>() {
    public int compare(String s1, String s2) {
        String[] arr1 = s1.split(" ");
        String[] arr2 = s2.split(" ");
        if(arr1[1].equals(arr2[1])) {
            return arr1[0].compareTo(arr2[0]);
        } else {
            return arr1[1].compareTo(arr2[1]);
        }
    }
});
System.out.println(Arrays.toString(strArr));

以上代码将输出:[A001 abc, A100 abc, A103 abc, B102 abc]。

七、字符串排序规则

在排序字符串时,按照什么规则进行排序是非常重要的。比如,只按照字母序进行排序,还是需要按照数字和字母混合排序等。

以下是一个示例代码:


String[] strArr = {"a2", "a11", "a1", "a999", "a100", "a20"};
Arrays.sort(strArr, new Comparator<String>() {
    public int compare(String s1, String s2) {
        String str1 = s1.replaceAll("\\D+", "");
        String str2 = s2.replaceAll("\\D+", "");
        if(str1.equals(str2)) {
            return s1.compareTo(s2);
        } else {
            return Integer.parseInt(str1) - Integer.parseInt(str2);
        }
    }
});
System.out.println(Arrays.toString(strArr));

以上代码将输出:[a1, a2, a11, a20, a100, a999]。

八、字符串排序什么意思

字符串排序的意思就是根据一定的规则对字符串进行排序。

在Java中,常见的排序方法有Arrays.sort()和Collections.sort()。使用这些方法可以对字符串按照字典序、数字和字母混合等进行排序。

九、字符串排序按什么排的

在进行字符串排序时,按照什么规则进行排序是非常重要的。按照字典序排序时,会按照从左到右的顺序将每个字符的Unicode码值进行比较,如果当前字符的Unicode码值小于比较字符的Unicode码值,则当前字符串小于比较字符串;如果当前字符的Unicode码值大于比较字符的Unicode码值,则当前字符串大于比较字符串。

如果需要按照其他规则进行排序,则需要自定义比较器,并重写其compare()方法。

十、字符串排序C语言

在C语言中,可以使用qsort()函数进行字符串排序。需要自定义比较器,并传入函数中。

以下是一个示例代码:


#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int cmp(const void* p1, const void* p2)
{
    return strcmp(*(const char**)p1, *(const char**)p2);
}

int main()
{
    char* strArr[] = {"apple", "banana", "pear", "orange"};
    qsort(strArr, sizeof(strArr) / sizeof(strArr[0]), sizeof(strArr[0]), cmp);
    for(int i = 0; i < sizeof(strArr) / sizeof(strArr[0]); i++) {
        printf("%s ", strArr[i]);
    }
    return 0;
}

以上代码将输出:apple banana orange pear。