推薦答案
要在Java中對字符串進行排序,將大寫字母排在前面,小寫字母排在后面,可以使用自定義的比較器(Comparator)來實現(xiàn)。以下是一種可能的實現(xiàn)方式:
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class StringSort {
public static void main(String[] args) {
List strings = new ArrayList<>();
strings.add("Hello");
strings.add("World");
strings.add("java");
strings.add("OpenAI");
strings.add("Language");
strings.add("Model");
// 使用自定義的比較器進行排序
Collections.sort(strings, new CustomComparator());
// 打印排序結果
for (String str : strings) {
System.out.println(str);
}
}
static class CustomComparator implements Comparator {
@Override
public int compare(String s1, String s2) {
boolean s1UpperCase = Character.isUpperCase(s1.charAt(0));
boolean s2UpperCase = Character.isUpperCase(s2.charAt(0));
// 如果s1是大寫字母而s2是小寫字母,則s1排在s2前面
if (s1UpperCase && !s2UpperCase) {
return -1;
}
// 如果s1是小寫字母而s2是大寫字母,則s2排在s1前面
else if (!s1UpperCase && s2UpperCase) {
return 1;
}
// 否則,使用默認的字符串比較
else {
return s1.compareTo(s2);
}
}
}
}
上述代碼中,我們首先創(chuàng)建了一個字符串列表,并添加了一些字符串數(shù)據(jù)。然后,我們使用Collections.sort()方法對字符串列表進行排序,并傳入自定義的比較器CustomComparator。比較器根據(jù)字符串的首字母的大小寫來確定排序順序,大寫字母排在小寫字母之前。最后,按照排序順序打印字符串列表的內(nèi)容。
輸出結果為:
Language
Model
OpenAI
Hello
World
java
以上代碼演示了如何使用自定義比較器對字符串進行排序,實現(xiàn)了大寫字母在前,小寫字母在后的需求。
其他答案
-
要在Java中對字符串進行排序,將大寫字母排在前面,小寫字母排在后面,可以通過自定義的比較規(guī)則來實現(xiàn)。以下是一種可能的實現(xiàn)方式:
import java.util.Arrays;
public class StringSort {
public static void main(String[] args) {
String[] strings = {"Hello", "World", "java", "OpenAI", "Language", "Model"};
// 使用自定義比較規(guī)則進行排序
Arrays.sort(strings, (s1, s2) -> {
boolean s1UpperCase = Character.isUpperCase(s1.charAt(0));
boolean s2UpperCase = Character.isUpperCase(s2.charAt(0));
// 如果s1是大寫字母而s2是小寫字母,則s1排在s2前面
if (s1UpperCase && !s2UpperCase) {
return -1;
}
// 如果s1是小寫字母而s2是大寫字母,則s2排在s1前面
else if (!s1UpperCase && s2UpperCase) {
return 1;
}
// 否則,使用默認的字符串比較
else {
return s1.compareTo(s2);
}
});
// 打印排序結果
for (String str : strings) {
System.out.println(str);
}
}
}
在上述代碼中,我們創(chuàng)建了一個字符串數(shù)組,并初始化了一些字符串數(shù)據(jù)。然后,我們使用Arrays.sort()方法對字符串數(shù)組進行排序,并傳入一個Lambda表達式作為比較器。比較器根據(jù)字符串的首字母的大小寫來確定排序順序,大寫字母排在小寫字母之前。最后,按照排序順序打印字符串數(shù)組的內(nèi)容。
輸出結果為:
Language
Model
OpenAI
Hello
World
java
以上代碼演示了如何使用自定義比較規(guī)則對字符串進行排序,以滿足大寫字母在前,小寫字母在后的需求。
-
要在Java中對字符串進行排序,將大寫字母排在前面,小寫字母排在后面,可以使用Arrays.sort()方法,并傳入自定義的比較器來實現(xiàn)。以下是一種可能的實現(xiàn)方式:
import java.util.Arrays;
import java.util.Comparator;
public class StringSort {
public static void main(String[] args) {
String[] strings = {"Hello", "World", "java", "OpenAI", "Language", "Model"};
// 使用自定義的字符串比較器進行排序
Arrays.sort(strings, new CustomComparator());
// 打印排序結果
for (String str : strings) {
System.out.println(str);
}
}
static class CustomComparator implements Comparator {
@Override
public int compare(String s1, String s2) {
boolean s1UpperCase = Character.isUpperCase(s1.charAt(0));
boolean s2UpperCase = Character.isUpperCase(s2.charAt(0));
// 如果s1是大寫字母而s2是小寫字母,則s1排在s2前面
if (s1UpperCase && !s2UpperCase) {
return -1;
}
// 如果s1是小寫字母而s2是大寫字母,則s2排在s1前面
else if (!s1UpperCase && s2UpperCase) {
return 1;
}
// 否則,使用默認的字符串比較
else {
return s1.compareTo(s2);
}
}
}
}
上述代碼中,我們創(chuàng)建了一個字符串數(shù)組,并初始化了一些字符串數(shù)據(jù)。然后,我們使用Arrays.sort()方法對字符串數(shù)組進行排序,并傳入自定義的比較器CustomComparator。比較器根據(jù)字符串的首字母的大小寫來確定排序順序,大寫字母排在小寫字母之前。最后,按照排序順序打印字符串數(shù)組的內(nèi)容。
輸出結果為:
Language
Model
OpenAI
Hello
World
java
以上代碼演示了如何使用自定義比較器對字符串進行排序,以滿足將大寫字母排在前面,小寫字母排在后面的需求。