Java實(shí)現(xiàn)快速排序算法的完整示例
首先,來看一下,快速排序的實(shí)現(xiàn)的動(dòng)態(tài)圖:

快速排序介紹:
快速排序,根據(jù)教科書說法來看,是冒泡排序的一種改進(jìn)。
快速排序,由一個(gè)待排序的數(shù)組(array),以及找準(zhǔn)三個(gè)變量:
- 中樞值(pivot)
- 左值(left)
- 右值(right)
根據(jù)中樞值(pivot)來做調(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ū)分開來。
再根據(jù) 遞歸思想 , 對(duì) 左邊數(shù)組 、 中樞值 、 右邊數(shù)組 不斷遞歸循環(huán)操作,不斷拆分出三部分來,最終達(dá)到快速排序的效果。
核心邏輯:

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

接下來附上完整實(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ù)組值大于中樞值,說明不需要調(diào)整位置,則讓右值(right)自減1
while (left < right && ary[right] >= pivot) {
right--; // 執(zhí)行自減操作
}
// 如果上面循環(huán)不符合條件的,則說明右邊數(shù)組的一個(gè)值,小于中樞值(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ù)組的一個(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),來對(duì)左邊數(shù)組進(jìn)行遞歸調(diào)用快速排序
quickSort(ary, left, pivot - 1);
// 根據(jù)中樞值(pivot),來對(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)文章
java寫卷積神經(jīng)網(wǎng)絡(luò)(CupCnn簡介)
這篇文章主要介紹了java寫卷積神經(jīng)網(wǎng)絡(luò)(CupCnn簡介),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-04-04
Java8日期時(shí)間類LocalDateTime比較大小舉例
LocalDate是Java?8中的日期類之一,它表示一個(gè)日期,下面這篇文章主要給大家介紹了關(guān)于Java8日期時(shí)間類LocalDateTime比較大小的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05
Mybatis基于xml配置實(shí)現(xiàn)單表的增刪改查功能
這篇文章主要介紹了Mybatis基于xml配置實(shí)現(xiàn)單表的增刪改查,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04
spring中使用mybatis實(shí)現(xiàn)批量插入的示例代碼
這篇文章主要介紹了spring中使用mybatis實(shí)現(xiàn)批量插入的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
Java中Spring MVC接收表單數(shù)據(jù)的常用方法
Spring MVC是Spring框架中的一個(gè)模塊,用于開發(fā)基于MVC(Model-View-Controller)架構(gòu)的Web應(yīng)用程序,它提供了一種輕量級(jí)的、靈活的方式來構(gòu)建Web應(yīng)用,同時(shí)提供了豐富的功能和特性,本文給大家介紹了Spring MVC接收表單數(shù)據(jù)的方法,需要的朋友可以參考下2024-05-05
解決maven update project 后項(xiàng)目jdk變成1.5的問題
下面小編就為大家?guī)硪黄鉀Qmaven update project 后項(xiàng)目jdk變成1.5的問題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起 小編過來看看吧2016-11-11
java發(fā)送HttpClient請(qǐng)求及接收請(qǐng)求結(jié)果過程的簡單實(shí)例
下面小編就為大家?guī)硪黄猨ava發(fā)送HttpClient請(qǐng)求及接收請(qǐng)求結(jié)果過程的簡單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11
java使用Socket類接收和發(fā)送數(shù)據(jù)
Socket類是負(fù)責(zé)處理客戶端通信的Java類。本文主要是介紹java使用Socket類接收和發(fā)送數(shù)據(jù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-10-10
Spring Boot整合EasyExcel(完整版包含上傳解析excel和下載模板)
這篇文章主要介紹了Spring Boot整合EasyExcel(完整版包含上傳解析excel和下載模板),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12

