日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪(fǎng)問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > java >内容正文

java

Java Arrays.sort()的几种用法

發(fā)布時(shí)間:2025/3/21 java 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java Arrays.sort()的几种用法 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.



Java的Arrays類(lèi)中有一個(gè)sort()方法,該方法是Arrays類(lèi)的靜態(tài)方法,在需要對(duì)數(shù)組進(jìn)行排序時(shí),非常的好用。

但是sort()的參數(shù)有好幾種,下面我就為大家一一介紹,這幾種形式的用法。

======================================================

1、Arrays.sort(int[] a)

這種形式是對(duì)一個(gè)數(shù)組的所有元素進(jìn)行排序,并且是按從小到大的順序。

舉例如下(點(diǎn)“+”可查看代碼):

  • 1 importjava.util.Arrays;
  • 2
  • 3 public class Main {
  • 4 public static void main(String[] args) {
  • 5
  • 6 int[] a = {9, 8, 7, 2, 3, 4, 1, 0, 6, 5};
  • 7 Arrays.sort(a);
  • 8 for(int i = 0; i < a.length; i ++) {
  • 9 System.out.print(a[i] + " ");
  • 10 }
  • 11 }
  • 12
  • 13 }
  • View Code

    運(yùn)行結(jié)果如下:

    0 1 2 3 4 5 6 7 8 9?

    ---------------------------------------------------------

    2、Arrays.sort(int[] a, int fromIndex, int toIndex)

    這種形式是對(duì)數(shù)組部分排序,也就是對(duì)數(shù)組a的下標(biāo)從fromIndex到toIndex-1的元素排序,注意:下標(biāo)為toIndex的元素不參與排序哦!

    舉例如下(點(diǎn)“+”可查看代碼):

  • 1 importjava.util.Arrays;
  • 2
  • 3 public class Main {
  • 4 public static void main(String[] args) {
  • 5
  • 6 int[] a = {9, 8, 7, 2, 3, 4, 1, 0, 6, 5};
  • 7 Arrays.sort(a, 0, 3);
  • 8 for(int i = 0; i < a.length; i ++) {
  • 9 System.out.print(a[i] + " ");
  • 10 }
  • 11 }
  • 12
  • 13 }
  • View Code

    運(yùn)行結(jié)果如下:

    7 8 9 2 3 4 1 0 6 5?

    上例只是把 9 8 7排列成了7 8 9

    ----------------------------------------------------------

    3、public static <T> void sort(T[] a,int fromIndex,?int toIndex,??Comparator<? super T> c)

    上面有一個(gè)拘束,就是排列順序只能是從小到大,如果我們要從大到小,就要使用這種方式

    這里牽扯到了Java里面的泛型,如果讀者不是很了解,可以暫時(shí)不去管它,如果真的很想了解,建議查閱上面我推薦的那本書(shū),上面有詳細(xì)的介紹。

    讀者只需要讀懂下面的例子就可以了,其實(shí)就是多了一個(gè)Comparator類(lèi)型的參數(shù)而已。

  • 1 packagetest;
  • 2
  • 3 importjava.util.Arrays;
  • 4 importjava.util.Comparator;
  • 5
  • 6 public class Main {
  • 7 public static void main(String[] args) {
  • 8 //注意,要想改變默認(rèn)的排列順序,不能使用基本類(lèi)型(int,double, char)
  • 9 //而要使用它們對(duì)應(yīng)的類(lèi)
  • 10 Integer[] a = {9, 8, 7, 2, 3, 4, 1, 0, 6, 5};
  • 11 //定義一個(gè)自定義類(lèi)MyComparator的對(duì)象
  • 12 Comparator cmp = newMyComparator();
  • 13 Arrays.sort(a, cmp);
  • 14 for(int i = 0; i < a.length; i ++) {
  • 15 System.out.print(a[i] + " ");
  • 16 }
  • 17 }
  • 18 }
  • 19 //Comparator是一個(gè)接口,所以這里我們自己定義的類(lèi)MyComparator要implents該接口
  • 20 //而不是extends Comparator
  • 21 class MyComparator implements Comparator<Integer>{
  • 22 @Override
  • 23 public int compare(Integer o1, Integer o2) {
  • 24 //如果o1小于o2,我們就返回正值,如果o1大于o2我們就返回負(fù)值,
  • 25 //這樣顛倒一下,就可以實(shí)現(xiàn)反向排序了
  • 26 if(o1 <o2) {
  • 27 return 1;
  • 28 }else if(o1 >o2) {
  • 29 return -1;
  • 30 }else{
  • 31 return 0;
  • 32 }
  • 33 }
  • 34
  • 35 }
  • View Code

    運(yùn)行結(jié)果如下:

    9 8 7 6 5 4 3 2 1 0?


    總結(jié)

    以上是生活随笔為你收集整理的Java Arrays.sort()的几种用法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。