溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java中運(yùn)用數(shù)組的四種排序方法分別是什么

發(fā)布時(shí)間:2021-10-29 09:55:36 來源:億速云 閱讀:133 作者:柒染 欄目:編程語言

本篇文章給大家分享的是有關(guān)Java中運(yùn)用數(shù)組的四種排序方法分別是什么,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

JAVA中在運(yùn)用數(shù)組進(jìn)行排序功能時(shí),一般有四種方法:快速排序法、冒泡法、選擇排序法、插入排序法。

快速排序法主要是運(yùn)用了Arrays中的一個(gè)方法Arrays.sort()實(shí)現(xiàn)。

冒泡法是運(yùn)用遍歷數(shù)組進(jìn)行比較,通過不斷的比較將最小值或者***值一個(gè)一個(gè)的遍歷出來。

選擇排序法是將數(shù)組的***個(gè)數(shù)據(jù)作為***或者最小的值,然后通過比較循環(huán),輸出有序的數(shù)組。

插入排序是選擇一個(gè)數(shù)組中的數(shù)據(jù),通過不斷的插入比較***進(jìn)行排序。下面我就將他們的實(shí)現(xiàn)方法。

<1>利用Arrays帶有的排序方法快速排序

import java.util.Arrays; 2 public class Test2{           public static void main(String[] args){                   int[] a={5,4,2,4,9,1};                   Arrays.sort(a);  //進(jìn)行排序                   for(int i: a){                           System.out.print(i);                  }          }  }

<2>冒泡排序算法

public static int[] bubbleSort(int[] args){//冒泡排序算法           for(int i=0;i<args.length-1;i++){                  for(int j=i+1;j<args.length;j++){                      if (args[i]>args[j]){                          int temp=args[i];                          args[i]=args[j];                          args[j]=temp;                          }               }         }         return args;  }

<3>選擇排序算法

public static int[] selectSort(int[] args){//選擇排序算法            for (int i=0;i<args.length-1 ;i++ ){                   int min=i;                   for (int j=i+1;j<args.length ;j++ ){                         if (args[min]>args[j]){                              min=j;                              }                     }                         if (min!=i){                        int temp=args[i];                        args[i]=args[min];                        args[min]=temp;                            }              }               return args;      }

<4>插入排序算法

public static int[] insertSort(int[] args){//插入排序算法                    for(int i=1;i<args.length;i++){                            for(int j=i;j>0;j--){                                    if (args[j]<args[j-1]){                                            int temp=args[j-1];                                           args[j-1]=args[j];                                          args[j]=temp;                                          }else break;                           }                   }                   return args;           }

以上就是java中的四種排序方法。不同的方法效率不一樣,下面是不同的算法的比較和數(shù)據(jù)交換時(shí)的大O表示。

冒泡排序:比較O(N2) 數(shù)據(jù)交換O(N2)

選擇排序:比較O(N2) 數(shù)據(jù)交換O(N)

插入排序:比較O(N2) 復(fù)制數(shù)據(jù)O(N)

在實(shí)際應(yīng)用中,我們要盡量選擇效率高的算法。

以上就是Java中運(yùn)用數(shù)組的四種排序方法分別是什么,小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI