java通過Arrays.sort(int[] a)實(shí)現(xiàn)由大到小排序的方法實(shí)現(xiàn)
一、方法重載
Arrays.sort()
方法有許多重載版本,可以接受不同類型的輸入,并對它們進(jìn)行排序。以下是一些常見的重載版本:
Arrays.sort(byte[] a)
: 對字節(jié)型數(shù)組進(jìn)行排序Arrays.sort(char[] a)
: 對字符型數(shù)組進(jìn)行排序Arrays.sort(double[] a)
: 對雙精度浮點(diǎn)型數(shù)組進(jìn)行排序Arrays.sort(float[] a)
: 對浮點(diǎn)型數(shù)組進(jìn)行排序Arrays.sort(int[] a)
: 對整型數(shù)組進(jìn)行排序Arrays.sort(long[] a)
: 對長整型數(shù)組進(jìn)行排序Arrays.sort(short[] a)
: 對短整型數(shù)組進(jìn)行排序Arrays.sort(Object[] a)
: 對對象數(shù)組進(jìn)行排序,此方法要求數(shù)組中的對象必須實(shí)現(xiàn)了Comparable
接口Arrays.sort(T[] a, Comparator<? super T> c)
: 對對象數(shù)組進(jìn)行排序,使用一個定制的Comparator
對象來比較數(shù)組中的元素
二、注意事項(xiàng)
對于對象數(shù)組,如果使用默認(rèn)的
Arrays.sort(Object[] a)
方法進(jìn)行排序,那么數(shù)組中的對象必須實(shí)現(xiàn)了Comparable
接口。如果對象沒有實(shí)現(xiàn)這個接口,那么在運(yùn)行時會拋出ClassCastException
。Arrays.sort(T[] a, Comparator<? super T> c)
這個版本的方法允許你傳入一個Comparator
對象來自定義排序的規(guī)則。如果傳入的Comparator
對象為null
,那么此方法將會使用元素的自然順序進(jìn)行排序。對于對象數(shù)組的排序,
Arrays.sort()
方法使用的是穩(wěn)定的排序算法,這意味著等值的元素在排序后會保持他們原有的相對位置。Arrays.sort()
方法的時間復(fù)雜性為O(n log n)。Arrays.sort()
方法會對輸入的數(shù)組進(jìn)行直接排序,也就是說,它會改變輸入數(shù)組的元素順序。如果不希望改變原數(shù)組的元素順序,那么在排序前需要先對數(shù)組進(jìn)行復(fù)制。
三、舉例
java的Arrays.sort(int[] a)實(shí)現(xiàn)的是由小到大的排序,那么如果要實(shí)現(xiàn)由大到小排序怎么辦呢?一種方法是用下面的步驟:
1)先通過Arrays.sort(int[] a)對數(shù)組a實(shí)現(xiàn)由小到大排序;
2)然后創(chuàng)建另外一個同長度的數(shù)組b,將數(shù)組a的元素從后面往前拷貝到b數(shù)組中;
3)通過System.arraycopy將數(shù)組b的內(nèi)容拷貝到數(shù)組a中。
import java.util.Arrays; public class Test { public static void main(String[] args) { int[] a = {1, 3, 2, 4}; int[] b = new int[a.length]; Arrays.sort(a); // 將數(shù)組a的內(nèi)容由小到大排序 // 將數(shù)組a的內(nèi)容從后到前拷貝到數(shù)組b中 for (int i = 0; i < a.length; i ++) { b[a.length -1 - i] = a[i]; } System.arraycopy(b, 0, a, 0, a.length); // 將數(shù)組b的內(nèi)容拷貝到數(shù)組a中 System.out.println("content in array a:"); for (int i = 0; i < a.length; i++) { System.out.print(a[i] + ","); } System.out.println(); } }
輸出內(nèi)容:
到此這篇關(guān)于java中的Arrays.sort()排序方法實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)java Arrays.sort排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java實(shí)現(xiàn)隨機(jī)驗(yàn)證碼圖片生成
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)隨機(jī)驗(yàn)證碼圖片生成,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11最全JVM調(diào)優(yōu)步驟和參數(shù)及配置
這篇文章主要給大家介紹了關(guān)于JVM調(diào)優(yōu)的相關(guān)資料,JVM調(diào)優(yōu)是指對Java虛擬機(jī)(JVM)進(jìn)行優(yōu)化,以提高Java程序的性能和運(yùn)行效率,文中介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03java基于C/S模式實(shí)現(xiàn)聊天程序(服務(wù)器)
這篇文章主要為大家詳細(xì)介紹了java基于C/S模式實(shí)現(xiàn)聊天程序的服務(wù)器篇,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01java使用HttpSession實(shí)現(xiàn)QQ訪問記錄
這篇文章主要介紹了java使用HttpSession實(shí)現(xiàn)QQ的訪問記錄的相關(guān)資料,需要的朋友可以參考下2016-03-03spring boot配置讀寫分離的完整實(shí)現(xiàn)步驟
數(shù)據(jù)庫配置主從之后,如何在代碼層面實(shí)現(xiàn)讀寫分離?所以下面這篇文章主要給大家介紹了關(guān)于spring boot配置讀寫分離的完整步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2018-09-09