一、字符串排序
在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。
原創文章,作者:EHMJB,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/332191.html