亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java實現(xiàn)快速排序算法的完整示例

 更新時間:2020年12月11日 09:23:03   作者:Java極客思維  
這篇文章主要給大家介紹了關(guān)于Java實現(xiàn)快速排序算法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

首先,來看一下,快速排序的實現(xiàn)的動態(tài)圖:

快速排序介紹:

快速排序,根據(jù)教科書說法來看,是冒泡排序的一種改進(jìn)。

快速排序,由一個待排序的數(shù)組(array),以及找準(zhǔn)三個變量:

  • 中樞值(pivot)
  • 左值(left)
  • 右值(right)

根據(jù)中樞值(pivot)來做調(diào)整,將數(shù)組(array)分為三個部分:

  • 第一部分:中樞值(pivot),單獨數(shù)字構(gòu)成,這個值在每次排序好的"最中間";
  • 第二部分:左邊數(shù)組(由array的一部分組成),這個數(shù)組在第一部分 中樞值(pivot) 的"左邊",其中左邊數(shù)組中的每一個值(不一定是排序好的,可能是亂序的),都要比中樞值和右邊數(shù)組的值要?。?/li>
  • 第三部分:右邊數(shù)組(由array的一部分組成),這個數(shù)組在第一部分 中樞值(pivot)的"右邊",其中右邊數(shù)組的每一個值(不一定是排序好的,可能是亂序的),都要比中樞值和左邊數(shù)組的值要大

以上就是快速排序要做的第一步,將數(shù)組按照:左邊數(shù)組 、 中樞值 、 右邊數(shù)組 區(qū)分開來。

再根據(jù) 遞歸思想 , 對 左邊數(shù)組 、 中樞值 、 右邊數(shù)組 不斷遞歸循環(huán)操作,不斷拆分出三部分來,最終達(dá)到快速排序的效果。

核心邏輯:

快排算法遞歸調(diào)用:

接下來附上完整實現(xiàn)代碼:

public class QuickSort {

 /**
  * 快速排序調(diào)用方法
  *
  * @param ary 待排序數(shù)組
  * @param left 左值
  * @param right 右值
  * @return int值
  * @author Cansluck
  */
 public static int getSortNum(int[] ary, int left, int right) {
  // 定義一個中樞值pivot,讓其等于數(shù)組的左值,樞軸選定后永遠(yuǎn)不變,最終在中間,前小后大
  int pivot = ary[left];
  while (left < right) {
   // 看后面ary[right] > pivot比較,如果右邊數(shù)組值大于中樞值,說明不需要調(diào)整位置,則讓右值(right)自減1
   while (left < right && ary[right] >= pivot) {
    right--; // 執(zhí)行自減操作
   }
   // 如果上面循環(huán)不符合條件的,則說明右邊數(shù)組的一個值,小于中樞值(pivot),則將其替換到左邊數(shù)組中
   ary[left] = ary[right];
   // 看后面ary[left] < pivot比較,如果左邊數(shù)組值小于中樞值,說明不需要調(diào)整位置,則讓左值(left)自增1
   while (left < right && ary[left] <= pivot) {
    left++; // 執(zhí)行自增操作
   }
   // 如果上面循環(huán)不符合條件,則說明左邊數(shù)組的一個值,大于中樞值(pivot),則將其替換到右邊數(shù)組中
   ary[right] = ary[left];
  }
  // 最后將中樞值給自增后的左邊數(shù)組的一個值中
  ary[left] = pivot;
  // 返回左邊數(shù)組下標(biāo)
  return left;
 }

 /**
  * 快速排序遞歸方法
  *
  * @author Cansluck
  * @param ary 待排序數(shù)組
  * @param left 左值
  * @param right 右值
  */
 public static void quickSort(int[] ary, int left, int right) {
  // 定義中樞值
  int pivot;
  // 判斷
  if (left < right) {
   // 根據(jù)方法得到了每次中樞值的位置
   pivot = getSortNum(ary, left, right);
   // 根據(jù)中樞值(pivot),來對左邊數(shù)組進(jìn)行遞歸調(diào)用快速排序
   quickSort(ary, left, pivot - 1);
   // 根據(jù)中樞值(pivot),來對右邊數(shù)組進(jìn)行遞歸調(diào)用快速排序
   quickSort(ary, pivot + 1, right);
  }
 }

 public static void main(String[] args) {
  int[] ary = {97, 58, 12, 88, 77, 22, 33, 44, 66, 22};
  quickSort(ary, 0, ary.length - 1);
  for (int i = 0; i < ary.length; i++) {
   if (i != ary.length - 1)
    System.out.print(ary[i] + ", ");
   else
    System.out.println(ary[i]);
  }
 }
}

以上就是快速排序的詳細(xì)介紹及完整實現(xiàn)。有興趣的小伙伴也自行實現(xiàn)以下吧~

到此這篇關(guān)于Java實現(xiàn)快速排序算法的文章就介紹到這了,更多相關(guān)Java實現(xiàn)快速排序算法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring?Data?JPA注解Entity使用示例詳解

    Spring?Data?JPA注解Entity使用示例詳解

    這篇文章主要為大家介紹了Spring?Data?JPA注解Entity使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • Mapper類中存在名稱相同的方法重載報錯問題

    Mapper類中存在名稱相同的方法重載報錯問題

    這篇文章主要介紹了Mapper類中存在名稱相同的方法重載報錯問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • SpringSecurity默認(rèn)登錄頁的使用示例教程

    SpringSecurity默認(rèn)登錄頁的使用示例教程

    Spring 是非常流行和成功的 Java 應(yīng)用開發(fā)框架,Spring Security 正是 Spring 家族中的成員,Spring Security 基于 Spring 框架,提供了一套 Web 應(yīng)用安全性的完整解決方案,本文給大家介紹SpringSecurity的默認(rèn)登錄頁的使用教程,感興趣的朋友一起看看吧
    2023-12-12
  • 教你怎么用java實現(xiàn)客戶端與服務(wù)器一問一答

    教你怎么用java實現(xiàn)客戶端與服務(wù)器一問一答

    這篇文章主要介紹了教你怎么用java實現(xiàn)客戶端與服務(wù)器一問一答,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • Netty + ZooKeeper 實現(xiàn)簡單的服務(wù)注冊與發(fā)現(xiàn)

    Netty + ZooKeeper 實現(xiàn)簡單的服務(wù)注冊與發(fā)現(xiàn)

    服務(wù)注冊和發(fā)現(xiàn)一直是分布式的核心組件。本文介紹了借助 ZooKeeper 做注冊中心,如何實現(xiàn)一個簡單的服務(wù)注冊和發(fā)現(xiàn)。,需要的朋友可以參考下
    2019-06-06
  • JavaWeb文件上傳與下載功能解析

    JavaWeb文件上傳與下載功能解析

    這篇文章主要為大家詳細(xì)介紹了JavaWeb文件上傳與下載功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-06-06
  • Spring配置文件解析之BeanDefinitionParserDelegate詳解

    Spring配置文件解析之BeanDefinitionParserDelegate詳解

    這篇文章主要介紹了Spring配置文件解析之BeanDefinitionParserDelegate詳解,對于Spring的配置文件的解析處理操作是在BeanDefinitionParserDelegate中進(jìn)行處理操作,接下來我們簡單介紹一下BeanDefinitionParserDelegate所做的處理操作,需要的朋友可以參考下
    2024-02-02
  • Java如何通過屬性名獲取Object對象屬性值

    Java如何通過屬性名獲取Object對象屬性值

    這篇文章主要介紹了Java如何通過屬性名獲取Object對象屬性值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • SSM如何實現(xiàn)在Controller中添加事務(wù)管理

    SSM如何實現(xiàn)在Controller中添加事務(wù)管理

    這篇文章主要介紹了SSM如何實現(xiàn)在Controller中添加事務(wù)管理,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • 使用WebUploader實現(xiàn)分片斷點上傳文件功能(二)

    使用WebUploader實現(xiàn)分片斷點上傳文件功能(二)

    這篇文章主要為大家詳細(xì)介紹了使用WebUploader實現(xiàn)分片斷點上傳文件功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01

最新評論