更新時(shí)間:2022-11-07 11:13:27 來(lái)源:動(dòng)力節(jié)點(diǎn) 瀏覽2490次
我們?cè)趯W(xué)習(xí) Java 的過(guò)程中肯定會(huì)遇到對(duì)數(shù)組進(jìn)行升序或降序等排序問(wèn)題,本節(jié)主要介紹如何實(shí)現(xiàn) Java 數(shù)組的升序和降序。Java 語(yǔ)言使用 Arrays 類提供的 sort() 方法來(lái)對(duì)數(shù)組進(jìn)行排序。
使用 java.util.Arrays 類中的 sort() 方法對(duì)數(shù)組進(jìn)行升序分為以下兩步:
導(dǎo)入 java.util.Arrays 包。
使用 Arrays.sort(數(shù)組名) 語(yǔ)法對(duì)數(shù)組進(jìn)行排序,排序規(guī)則是從小到大,即升序。
假設(shè)在數(shù)組 scores 中存放了 5 名學(xué)生的成績(jī),現(xiàn)在要實(shí)現(xiàn)從低到高排列的功能。在這里使用 Arrays.sort() 方法來(lái)實(shí)現(xiàn),具體代碼如下:
public static void main(String[] args) {
// 定義含有5個(gè)元素的數(shù)組
double[] scores = new double[] { 78, 45, 85, 97, 87 };
System.out.println("排序前數(shù)組內(nèi)容如下:");
// 對(duì)scores數(shù)組進(jìn)行循環(huán)遍歷
for (int i = 0; i < scores.length; i++) {
System.out.print(scores[i] + "\t");
}
System.out.println("\n排序后的數(shù)組內(nèi)容如下:");
// 對(duì)數(shù)組進(jìn)行排序
Arrays.sort(scores);
// 遍歷排序后的數(shù)組
for (int j = 0; j < scores.length; j++) {
System.out.print(scores[j] + "\t");
}
}
如上述代碼所示,要對(duì)一個(gè)數(shù)組進(jìn)行升序排列,只需要調(diào)用 Arrays.sort() 方法即可。運(yùn)行后的輸出結(jié)果如下所示。
排序前數(shù)組內(nèi)容如下:
78.0 45.0 85.0 97.0 87.0
排序后的數(shù)組內(nèi)容如下:
45.0 78.0 85.0 87.0 97.0
在 Java 語(yǔ)言中使用 sort 實(shí)現(xiàn)降序有兩種方法,簡(jiǎn)單了解即可。
1.利用 Collections.reverseOrder() 方法(Collections 是一個(gè)Java包裝類。
public static void main(String[] args) {
Integer[] a = { 9, 8, 7, 2, 3, 4, 1, 0, 6, 5 }; // 數(shù)組類型為Integer
Arrays.sort(a, Collections.reverseOrder());
for (int arr : a) {
System.out.print(arr + " ");
}
}
輸出結(jié)果如下:
9 8 7 6 5 4 3 2 1 0
2.實(shí)現(xiàn) Comparator 接口的復(fù)寫(xiě) compare() 方法,代碼如下:
public class Test {
public static void main(String[] args) {
/*
* 注意,要想改變默認(rèn)的排列順序,不能使用基本類型(int,double,char)而要使用它們對(duì)應(yīng)的類
*/
Integer[] a = { 9, 8, 7, 2, 3, 4, 1, 0, 6, 5 };
// 定義一個(gè)自定義類MyComparator的對(duì)象
Comparator cmp = new MyComparator();
Arrays.sort(a, cmp);
for (int arr : a) {
System.out.print(arr + " ");
}
}
}
// 實(shí)現(xiàn)Comparator接口
class MyComparator implements Comparator<Integer> {
@Override
public int compare(Integer o1, Integer o2) {
/*
* 如果o1小于o2,我們就返回正值,如果o1大于o2我們就返回負(fù)值, 這樣顛倒一下,就可以實(shí)現(xiàn)降序排序了,反之即可自定義升序排序了
*/
return o2 - o1;
}
}
輸出結(jié)果如下所示。
9 8 7 6 5 4 3 2 1 0
注意:使用以上兩種方法時(shí),數(shù)組必須是包裝類型,否則會(huì)編譯不通過(guò)。
在 Java 中實(shí)現(xiàn)數(shù)組排序的方式很多,除了利用以上的幾種方法外,還可以編寫(xiě)自定義方法來(lái)實(shí)現(xiàn)自己的排序算法,有興趣的讀者可以嘗試編寫(xiě)。
對(duì)數(shù)組的排序:
//對(duì)數(shù)組排序
public void arraySort(){
int[] arr = {1,4,6,333,8,2};
Arrays.sort(arr);//使用java.util.Arrays對(duì)象的sort方法
for(int i=0;i<arr.length;i++){
System.out.println(arr[i]);
}
}
對(duì)集合的排序:
//對(duì)list升序排序
public void listSort1(){
List<Integer> list = new ArrayList<Integer>();
list.add(1);
list.add(55);
list.add(9);
list.add(0);
list.add(2);
Collections.sort(list);//使用Collections的sort方法
for(int a :list){
System.out.println(a);
}
}
//對(duì)list降序排序
public void listSort2(){
List<Integer> list = new ArrayList<Integer>();
list.add(1);
list.add(55);
list.add(9);
list.add(0);
list.add(2);
Collections.sort(list, new Comparator<Integer>() {
public int compare(Integer o1, Integer o2) {
return o2 - o1;
}
});//使用Collections的sort方法,并且重寫(xiě)compare方法
for(int a :list){
System.out.println(a);
}
}
以上就是關(guān)于“Java sort數(shù)組排序詳解”的介紹,大家如果想了解更多相關(guān)知識(shí),不妨來(lái)關(guān)注一下本站的Java基礎(chǔ)教程,里面還有更豐富的知識(shí)等著大家去學(xué)習(xí),希望對(duì)大家能夠有所幫助哦。
相關(guān)閱讀
Java實(shí)驗(yàn)班
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
Java就業(yè)班
有基礎(chǔ) 直達(dá)就業(yè)
Java夜校直播班
業(yè)余時(shí)間 高薪轉(zhuǎn)行
Java在職加薪班
工作1~3年,加薪神器
Java架構(gòu)師班
工作3~5年,晉升架構(gòu)
提交申請(qǐng)后,顧問(wèn)老師會(huì)電話與您溝通安排學(xué)習(xí)