一、字符串排序
在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。