电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java實現快速排序算法的完整示例

瀏覽:63日期:2022-08-19 15:26:29

首先,來看一下,快速排序的實現的動態圖:

Java實現快速排序算法的完整示例

快速排序介紹:

快速排序,根據教科書說法來看,是冒泡排序的一種改進。

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

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

根據中樞值(pivot)來做調整,將數組(array)分為三個部分:

第一部分:中樞值(pivot),單獨數字構成,這個值在每次排序好的'最中間'; 第二部分:左邊數組(由array的一部分組成),這個數組在第一部分 中樞值(pivot) 的'左邊',其中左邊數組中的每一個值(不一定是排序好的,可能是亂序的),都要比中樞值和右邊數組的值要小; 第三部分:右邊數組(由array的一部分組成),這個數組在第一部分 中樞值(pivot)的'右邊',其中右邊數組的每一個值(不一定是排序好的,可能是亂序的),都要比中樞值和左邊數組的值要大

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

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

核心邏輯:

Java實現快速排序算法的完整示例

快排算法遞歸調用:

Java實現快速排序算法的完整示例

接下來附上完整實現代碼:

public class QuickSort { /** * 快速排序調用方法 * * @param ary 待排序數組 * @param left 左值 * @param right 右值 * @return int值 * @author Cansluck */ public static int getSortNum(int[] ary, int left, int right) { // 定義一個中樞值pivot,讓其等于數組的左值,樞軸選定后永遠不變,最終在中間,前小后大 int pivot = ary[left]; while (left < right) { // 看后面ary[right] > pivot比較,如果右邊數組值大于中樞值,說明不需要調整位置,則讓右值(right)自減1 while (left < right && ary[right] >= pivot) { right--; // 執行自減操作 } // 如果上面循環不符合條件的,則說明右邊數組的一個值,小于中樞值(pivot),則將其替換到左邊數組中 ary[left] = ary[right]; // 看后面ary[left] < pivot比較,如果左邊數組值小于中樞值,說明不需要調整位置,則讓左值(left)自增1 while (left < right && ary[left] <= pivot) { left++; // 執行自增操作 } // 如果上面循環不符合條件,則說明左邊數組的一個值,大于中樞值(pivot),則將其替換到右邊數組中 ary[right] = ary[left]; } // 最后將中樞值給自增后的左邊數組的一個值中 ary[left] = pivot; // 返回左邊數組下標 return left; } /** * 快速排序遞歸方法 * * @author Cansluck * @param ary 待排序數組 * @param left 左值 * @param right 右值 */ public static void quickSort(int[] ary, int left, int right) { // 定義中樞值 int pivot; // 判斷 if (left < right) { // 根據方法得到了每次中樞值的位置 pivot = getSortNum(ary, left, right); // 根據中樞值(pivot),來對左邊數組進行遞歸調用快速排序 quickSort(ary, left, pivot - 1); // 根據中樞值(pivot),來對右邊數組進行遞歸調用快速排序 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]); } }}

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

到此這篇關于Java實現快速排序算法的文章就介紹到這了,更多相關Java實現快速排序算法內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 济南品牌包装设计公司_济南VI标志设计公司_山东锐尚文化传播 | 世纪豪门官网 世纪豪门集成吊顶加盟电话 世纪豪门售后电话 | 糖衣机,除尘式糖衣机,全自动糖衣机,泰州市长江制药机械有限公司 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | 除湿机|工业除湿机|抽湿器|大型地下室车间仓库吊顶防爆除湿机|抽湿烘干房|新风除湿机|调温/降温除湿机|恒温恒湿机|加湿机-杭州川田电器有限公司 | 活性氧化铝球|氧化铝干燥剂|分子筛干燥剂|氢氧化铝粉-淄博同心材料有限公司 | 制氮设备-变压吸附制氮设备-制氧设备-杭州聚贤气体设备制造有限公司 | 东莞办公家具厂家直销-美鑫【免费3D效果图】全国办公桌/会议桌定制 | 万濠影像仪(万濠投影仪)百科-苏州林泽仪器 | 磁粉制动器|张力控制器|气胀轴|伺服纠偏控制器整套厂家--台灵机电官网 | 不锈钢水箱生产厂家_消防水箱生产厂家-河南联固供水设备有限公司 | 企典软件一站式企业管理平台,可私有、本地化部署!在线CRM客户关系管理系统|移动办公OA管理系统|HR人事管理系统|人力 | 同步带轮_同步带_同步轮_iHF合发齿轮厂家-深圳市合发齿轮机械有限公司 | 粉碎机_塑料粉碎机_塑料破碎机厂家-星标机械 | 求是网 - 思想建党 理论强党 | 播音主持培训-中影人教育播音主持学苑「官网」-中国艺考界的贵族学校 | 3D全息投影_地面互动投影_360度立体投影_水幕灯光秀 | 广东银虎 蜂窝块状沸石分子筛-吸附脱硫分子筛-萍乡市捷龙环保科技有限公司 | 淘趣英语网 - 在线英语学习,零基础英语学习网站| 硬质合金模具_硬质合金非标定制_硬面加工「生产厂家」-西迪技术股份有限公司 | 高防护蠕动泵-多通道灌装系统-高防护蠕动泵-www.bjhuiyufluid.com慧宇伟业(北京)流体设备有限公司 | 进口试验机价格-进口生物材料试验机-西安卡夫曼测控技术有限公司 | 尾轮组_头轮组_矿用刮板_厢式刮板机_铸石刮板机厂家-双驰机械 | 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 青岛代理记账_青岛李沧代理记账公司_青岛崂山代理记账一个月多少钱_青岛德辉财税事务所官网 | 暴风影音| 扬尘在线监测系统_工地噪声扬尘检测仪_扬尘监测系统_贝塔射线扬尘监测设备「风途物联网科技」 | POM塑料_PBT材料「进口」聚甲醛POM杜邦原料、加纤PBT塑料报价格找利隆塑料 | 传动滚筒_厂家-淄博海恒机械制造厂 | bng防爆挠性连接管-定做金属防爆挠性管-依客思防爆科技 | 苏州伊诺尔拆除公司_专业酒店厂房拆除_商场学校拆除_办公楼房屋拆除_家工装拆除拆旧 | 对照品_中药对照品_标准品_对照药材_「格利普」高纯中药标准品厂家-成都格利普生物科技有限公司 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | 博医通医疗器械互联网供应链服务平台_博医通 | 数年网路-免费在线工具您的在线工具箱-shuyear.com | 精密钢管,冷拔精密无缝钢管,精密钢管厂,精密钢管制造厂家,精密钢管生产厂家,山东精密钢管厂家 | 防腐木批发价格_深圳_惠州_东莞防腐木厂家_森源(深圳)防腐木有限公司 | 双相钢_双相不锈钢_双相钢圆钢棒_双相不锈钢报价「海新双相钢」 双能x射线骨密度检测仪_dxa骨密度仪_双能x线骨密度仪_品牌厂家【品源医疗】 | 洛阳网站建设_洛阳网站优化_网站建设平台_洛阳香河网络科技有限公司 | 猎头招聘_深圳猎头公司_知名猎头公司 | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 锻造液压机,粉末冶金,拉伸,坩埚成型液压机定制生产厂家-山东威力重工官方网站 | 搪瓷搅拌器,搪玻璃搅拌器,搪玻璃冷凝器_厂家-淄博越宏化工设备 | 抓斗式清污机|螺杆式|卷扬式启闭机|底轴驱动钢坝|污水处理闸门-方源水利机械 |