Java實(shí)現(xiàn)快速排序算法的完整示例
首先,來(lái)看一下,快速排序的實(shí)現(xiàn)的動(dòng)態(tài)圖:
快速排序介紹:
快速排序,根據(jù)教科書(shū)說(shuō)法來(lái)看,是冒泡排序的一種改進(jìn)。
快速排序,由一個(gè)待排序的數(shù)組(array),以及找準(zhǔn)三個(gè)變量:
- 中樞值(pivot)
- 左值(left)
- 右值(right)
根據(jù)中樞值(pivot)來(lái)做調(diào)整,將數(shù)組(array)分為三個(gè)部分:
- 第一部分:中樞值(pivot),單獨(dú)數(shù)字構(gòu)成,這個(gè)值在每次排序好的"最中間";
- 第二部分:左邊數(shù)組(由array的一部分組成),這個(gè)數(shù)組在第一部分 中樞值(pivot) 的"左邊",其中左邊數(shù)組中的每一個(gè)值(不一定是排序好的,可能是亂序的),都要比中樞值和右邊數(shù)組的值要小;
- 第三部分:右邊數(shù)組(由array的一部分組成),這個(gè)數(shù)組在第一部分 中樞值(pivot)的"右邊",其中右邊數(shù)組的每一個(gè)值(不一定是排序好的,可能是亂序的),都要比中樞值和左邊數(shù)組的值要大
以上就是快速排序要做的第一步,將數(shù)組按照:左邊數(shù)組 、 中樞值 、 右邊數(shù)組 區(qū)分開(kāi)來(lái)。
再根據(jù) 遞歸思想 , 對(duì) 左邊數(shù)組 、 中樞值 、 右邊數(shù)組 不斷遞歸循環(huán)操作,不斷拆分出三部分來(lái),最終達(dá)到快速排序的效果。
核心邏輯:
快排算法遞歸調(diào)用:
接下來(lái)附上完整實(shí)現(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) { // 定義一個(gè)中樞值pivot,讓其等于數(shù)組的左值,樞軸選定后永遠(yuǎn)不變,最終在中間,前小后大 int pivot = ary[left]; while (left < right) { // 看后面ary[right] > pivot比較,如果右邊數(shù)組值大于中樞值,說(shuō)明不需要調(diào)整位置,則讓右值(right)自減1 while (left < right && ary[right] >= pivot) { right--; // 執(zhí)行自減操作 } // 如果上面循環(huán)不符合條件的,則說(shuō)明右邊數(shù)組的一個(gè)值,小于中樞值(pivot),則將其替換到左邊數(shù)組中 ary[left] = ary[right]; // 看后面ary[left] < pivot比較,如果左邊數(shù)組值小于中樞值,說(shuō)明不需要調(diào)整位置,則讓左值(left)自增1 while (left < right && ary[left] <= pivot) { left++; // 執(zhí)行自增操作 } // 如果上面循環(huán)不符合條件,則說(shuō)明左邊數(shù)組的一個(gè)值,大于中樞值(pivot),則將其替換到右邊數(shù)組中 ary[right] = ary[left]; } // 最后將中樞值給自增后的左邊數(shù)組的一個(gè)值中 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),來(lái)對(duì)左邊數(shù)組進(jìn)行遞歸調(diào)用快速排序 quickSort(ary, left, pivot - 1); // 根據(jù)中樞值(pivot),來(lái)對(duì)右邊數(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ì)介紹及完整實(shí)現(xiàn)。有興趣的小伙伴也自行實(shí)現(xiàn)以下吧~
到此這篇關(guān)于Java實(shí)現(xiàn)快速排序算法的文章就介紹到這了,更多相關(guān)Java實(shí)現(xiàn)快速排序算法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mapper類(lèi)中存在名稱(chēng)相同的方法重載報(bào)錯(cuò)問(wèn)題
這篇文章主要介紹了Mapper類(lèi)中存在名稱(chēng)相同的方法重載報(bào)錯(cuò)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03SpringSecurity默認(rèn)登錄頁(yè)的使用示例教程
Spring 是非常流行和成功的 Java 應(yīng)用開(kāi)發(fā)框架,Spring Security 正是 Spring 家族中的成員,Spring Security 基于 Spring 框架,提供了一套 Web 應(yīng)用安全性的完整解決方案,本文給大家介紹SpringSecurity的默認(rèn)登錄頁(yè)的使用教程,感興趣的朋友一起看看吧2023-12-12教你怎么用java實(shí)現(xiàn)客戶(hù)端與服務(wù)器一問(wèn)一答
這篇文章主要介紹了教你怎么用java實(shí)現(xiàn)客戶(hù)端與服務(wù)器一問(wèn)一答,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下2021-04-04Netty + ZooKeeper 實(shí)現(xiàn)簡(jiǎn)單的服務(wù)注冊(cè)與發(fā)現(xiàn)
服務(wù)注冊(cè)和發(fā)現(xiàn)一直是分布式的核心組件。本文介紹了借助 ZooKeeper 做注冊(cè)中心,如何實(shí)現(xiàn)一個(gè)簡(jiǎn)單的服務(wù)注冊(cè)和發(fā)現(xiàn)。,需要的朋友可以參考下2019-06-06Spring配置文件解析之BeanDefinitionParserDelegate詳解
這篇文章主要介紹了Spring配置文件解析之BeanDefinitionParserDelegate詳解,對(duì)于Spring的配置文件的解析處理操作是在BeanDefinitionParserDelegate中進(jìn)行處理操作,接下來(lái)我們簡(jiǎn)單介紹一下BeanDefinitionParserDelegate所做的處理操作,需要的朋友可以參考下2024-02-02Java如何通過(guò)屬性名獲取Object對(duì)象屬性值
這篇文章主要介紹了Java如何通過(guò)屬性名獲取Object對(duì)象屬性值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07SSM如何實(shí)現(xiàn)在Controller中添加事務(wù)管理
這篇文章主要介紹了SSM如何實(shí)現(xiàn)在Controller中添加事務(wù)管理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02使用WebUploader實(shí)現(xiàn)分片斷點(diǎn)上傳文件功能(二)
這篇文章主要為大家詳細(xì)介紹了使用WebUploader實(shí)現(xiàn)分片斷點(diǎn)上傳文件功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01