Java 實現快速排序算法:一條快速通道,分而治之

大家好,今天我們來聊聊快速排序(QuickSort)算法,這個經典的排序算法被廣泛應用于各種需要高效排序的場景。作為一種分治法(Divide and Conquer)算法,快速排序的效率在平均情況下非常高,是大多數排序算法中的“黃金選手”。那么,讓我們一起來了解如何在 Java 中實現快速排序吧!

一、什么是快速排序?

快速排序是一種基于分治法的排序算法,它的基本思想是通過選擇一個“基準”元素,將待排序的數組分成兩個子數組,使得一個子數組的所有元素都小于基準元素,另一個子數組的所有元素都大于基準元素。然后對這兩個子數組遞歸執行快速排序,最終完成排序。

快速排序的步驟:
  1. 從數組中選擇一個元素作為“基準”(pivot)。
  2. 將數組中所有比基準小的元素移到基準的左邊,比基準大的元素移到基準的右邊。
  3. 遞歸地對基準左邊和右邊的子數組進行排序。
  4. 當子數組的大小為 1 或者 0 時,停止遞歸,因為它們已經是有序的。

二、快速排序的時間復雜度

快速排序的時間復雜度是O(n log n),但在最壞情況下(比如每次選取的基準元素都是最小或最大的元素),它的時間復雜度會退化到O(n2)。然而,在平均情況下,快速排序的表現非常優秀,因此它通常被認為是高效的排序算法之一。

  • 最好和平均時間復雜度:O(n log n)
  • 最壞時間復雜度:O(n2)
  • 空間復雜度:O(log n)

三、Java 快速排序的實現

在 Java 中實現快速排序,我們需要編寫一個遞歸函數來進行分割和排序。具體步驟如下:

  1. 選擇基準元素:常見的選擇方式是選取數組的第一個元素、最后一個元素、或隨機選擇一個元素作為基準。
  2. 劃分數組:通過一個指針將數組分成兩個部分,一部分小于基準,另一部分大于基準。
  3. 遞歸排序子數組:對左邊和右邊的子數組分別遞歸執行快速排序。

下面是 Java 實現快速排序的代碼:

public class QuickSort {public static void sort(int[] arr, int left, int right) {//遞歸跳出條件:每個左右子數組的長度為1,大于和等于都要有if (left >= right) {return;}//基準數int base = arr[left];int i = left;int j = right;while (i < j) {//注意先從右向左找,注意沒有等號while (arr[j] > base && j > i) {j--;}//再從左往右找,注意要有等號while (arr[i] <= base && i < j) {i++;}//如果因為i = j跳出循環,那么沒必要進行交換if (i < j) {//交換兩元素位置int temp = arr[i];arr[i] = arr[j];arr[j] = temp;}}//交換基準與i=j的位置arr[left] = arr[i];arr[i] = base;//左右子數組遞歸排序sort(arr,left, i - 1);sort(arr, i + 1, right);}public static void main(String[] args) {int[] arr = {10, 7, 8, 9, 1, 5};System.out.println("原始數組:");printArray(arr);// 調用快速排序quickSort(arr, 0, arr.length - 1);System.out.println("排序后的數組:");printArray(arr);}
}

四、代碼解析

  1. quickSort 方法:這是快速排序的遞歸入口函數。它接收一個數組和數組的下標 lowhigh,表示待排序數組的范圍。如果 low 小于 high,就調用 partition 方法來劃分數組并遞歸排序。

  2. partition 方法:該方法用于選擇基準元素并將數組劃分為兩部分:

    • 所有小于基準的元素排在基準的左邊。
    • 所有大于基準的元素排在基準的右邊。 最后,基準元素會被放到它的正確位置,并返回該位置的索引。
  3. swap 方法:用于交換數組中兩個元素的位置。

  4. printArray 方法:用于打印數組,便于觀察排序結果。

五、輸出結果

假設我們使用的數組是 {10, 7, 8, 9, 1, 5},那么運行上述代碼后的輸出將會是:

原始數組:
10 7 8 9 1 5 
排序后的數組:
1 5 7 8 9 10 

可以看到,數組成功地按照從小到大的順序進行了排序。

六、優化與擴展

  1. 選擇基準優化

    • 在選擇基準時,避免總是選取第一個或最后一個元素,可以通過三數取中法來選擇基準元素,從而避免在已經部分有序的數組中出現最壞情況(O(n2))。

    示例:

    int mid = low + (high - low) / 2;
    int pivot = medianOfThree(arr[low], arr[mid], arr[high]);
    
  2. 尾遞歸優化

    快速排序是遞歸的,遞歸深度可能較深。通過尾遞歸優化,可以將較小的子數組放在棧中,而將較大的子數組先處理,減少棧的深度。
  3. 非遞歸實現

    快速排序也可以通過棧實現非遞歸版本,避免遞歸過深導致棧溢出。

七、小結

快速排序是一個高效的排序算法,通過分治法將問題逐步簡化。盡管它在最壞情況下的時間復雜度是 O(n2),但在平均情況下,其表現非常優異,尤其是在處理大量數據時。如果能優化基準選擇,快速排序的效率會進一步提升。希望通過本文的介紹,你對快速排序有了更深入的了解,并且能夠在 Java 中輕松實現這一經典算法!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/71917.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/71917.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/71917.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深入解析 Spring 中的 BeanDefinition 和 BeanDefinitionRegistry

在 Spring 框架中&#xff0c;BeanDefinition 和 BeanDefinitionRegistry 是兩個非常重要的概念&#xff0c;它們共同構成了 Spring IoC 容器的核心機制。本文將詳細介紹這兩個組件的作用、實現以及它們之間的關系。 一、BeanDefinition&#xff1a;Bean 的配置描述 1.1 什么…

《OpenCV》——光流估計

什么是光流估計&#xff1f; 光流估計的前提&#xff1f; 基本假設 亮度恒定假設&#xff1a;目標像素點的亮度在相鄰幀之間保持不變。這是光流計算的基礎假設&#xff0c;基于此可以建立數學方程來求解光流。時間連續或運動平滑假設&#xff1a;相鄰幀之間的時間間隔足夠小&a…

信息系統的安全防護

文章目錄 引言**1. 物理安全****2. 網絡安全****3. 數據安全****4. 身份認證與訪問控制****5. 應用安全****6. 日志與監控****7. 人員與管理制度****8. 其他安全措施****9. 安全防護框架**引言 從技術、管理和人員三個方面綜合考慮,構建多層次、多維度的安全防護體系。 信息…

如何進行OceanBase 運維工具的部署和表性能優化

本文來自OceanBase 用戶的實踐分享 隨著OceanBase數據庫應用的日益深入&#xff0c;數據量不斷攀升&#xff0c;單個表中存儲數百萬乃至數千萬條數據的情況變得愈發普遍。因此&#xff0c;部署專門的運維工具、實施針對性的表性能優化策略&#xff0c;以及加強指標監測工作&…

如何防止 Instagram 賬號被盜用:安全設置與注意事項

如何防止 Instagram 賬號被盜用&#xff1a;安全設置與注意事項 在這個數字化時代&#xff0c;社交媒體平臺如 Instagram 已成為我們日常生活的一部分。然而&#xff0c;隨著網絡犯罪的增加&#xff0c;保護我們的在線賬戶安全變得尤為重要。以下是一些關鍵的安全設置和注意事…

Redis|復制 REPLICA

文章目錄 是什么能干嘛怎么玩案例演示復制原理和工作流程復制的缺點 是什么 官網地址&#xff1a;https://redis.io/docs/management/replication/Redis 復制機制用于將數據從一個主節點&#xff08;Master&#xff09;復制到一個或多個從節點&#xff08;Slave&#xff09;&a…

對象存儲之Ceph

Ceph 對象存儲概述 Ceph 是一個開源分布式存儲系統&#xff0c;旨在提供高度可擴展、高度可用、容錯、性能優異的存儲解決方案。它結合了塊存儲、文件系統存儲和對象存儲的功能&#xff0c;且在設計上具有極高的可擴展性和靈活性。 在 Ceph 中&#xff0c;對象存儲&#xff0…

Document對象

DOM4j中&#xff0c;獲得Document對象的方式有三種&#xff1a; 1.讀取XML文件,獲得document對象 SAXReader reader new SAXReader(); Document document reader.read(new File("input.xml")); 2.解析XML形式的文本,得到document對象…

樹莓集團南京產業園再布局:深入剖析背后邏輯

在產業園區蓬勃發展的當下&#xff0c;樹莓集團在南京的產業園再布局行動備受矚目。這一舉措并非偶然&#xff0c;其背后蘊含著深刻且多元的戰略邏輯。 一、順應區域產業發展趨勢 南京作為長三角地區的重要城市&#xff0c;產業基礎雄厚且多元。近年來&#xff0c;南京大力推動…

Pytorch實現之腦電波圖像生成

簡介 簡介:采用雙GAN模型架構來生成腦電波與目標圖像。 論文題目:Image Generation from Brainwaves using Dual Generative Adversarial Training(使用雙生成對抗訓練的腦電波圖像生成) 會議:IEEE Global Conference on Consumer Electronics (GCCE) 摘要:表示通過無…

HTML解析 → DOM樹 CSS解析 → CSSOM → 合并 → 渲染樹 → 布局 → 繪制 → 合成 → 屏幕顯示

一、關鍵渲染流程 解析 HTML → 生成 DOM 樹 瀏覽器逐行解析 HTML&#xff0c;構建**DOM&#xff08;文檔對象模型&#xff09;**樹狀結構 遇到 <link> 或 <style> 標簽時會暫停 HTML 解析&#xff0c;開始加載 CSS 解析 CSS → 生成 CSSOM 將 CSS 規則解析為**…

劍指offer - 面試題11 旋轉數組的最小數字

題目鏈接&#xff1a;旋轉數組的最小數字 第一種&#xff1a;正確寫法&#xff08;num[m]和nums[r]比較&#xff09; class Solution { public:/*** 代碼中的類名、方法名、參數名已經指定&#xff0c;請勿修改&#xff0c;直接返回方法規定的值即可** * param nums int整型v…

Spring源碼分析の循環依賴

文章目錄 前言一、循環依賴問題二、循環依賴的解決三、整體流程分析 前言 常見的可能存在循環依賴的情況如下&#xff1a; 兩個bean中互相持有對方作為自己的屬性。 ??類似于&#xff1a; 兩個bean中互相持有對方作為自己的屬性&#xff0c;且在構造時就需要傳入&#xff1a…

Docker 部署 Jenkins持續集成(CI)工具

[TOC](Docker 部署 Jenkins持續集成(CI)工具) 前言 Jenkins 是一個流行的開源自動化工具&#xff0c;廣泛應用于持續集成&#xff08;CI&#xff09;和持續交付&#xff08;CD&#xff09;的環境中。通過 Docker 部署 Jenkins&#xff0c;可以簡化安裝和配置過程&#xff0c;并…

《Effective Objective-C》閱讀筆記(中)

目錄 接口與API設計 用前綴避免命名空間沖突 提供“全能初始化方法” 實現description方法 盡量使用不可變對象 使用清晰而協調的命名方式 方法命名 ?編輯類與協議命名 為私有方法名加前綴 理解OC錯誤模型 理解NSCopying協議 協議與分類 通過委托與數據源協議進行…

C++程序員內功修煉——Linux C/C++編程技術匯總

在軟件開發的宏大版圖中&#xff0c;C 語言宛如一座巍峨的高山&#xff0c;吸引著無數開發者攀登探索。而 Linux 操作系統&#xff0c;以其開源、穩定、高效的特性&#xff0c;成為了眾多開發者鐘愛的開發平臺。將 C 與 Linux 相結合&#xff0c;就如同為開發者配備了一把無堅不…

數據庫索引:缺點與類型全解析

在數據庫的世界里&#xff0c;索引就像是一本書的目錄&#xff0c;它能幫助我們快速定位到所需的數據&#xff0c;極大地提升查詢效率。然而&#xff0c;就如同任何事物都有兩面性一樣&#xff0c;索引也并非完美無缺。今天&#xff0c;我們就來深入探討一下索引的缺點以及常見…

【python】提取word\pdf格式內容到txt文件

一、使用pdfminer提取 import os import re from pdfminer.high_level import extract_text import docx2txt import jiebadef read_pdf(file_path):"""讀取 PDF 文件內容:param file_path: PDF 文件路徑:return: 文件內容文本"""try:text ext…

嵌入式八股文(五)硬件電路篇

一、名詞概念 1. 整流和逆變 &#xff08;1&#xff09;整流&#xff1a;整流是將交流電&#xff08;AC&#xff09;轉變為直流電&#xff08;DC&#xff09;。常見的整流電路包括單向整流&#xff08;二極管&#xff09;、橋式整流等。 半波整流&#xff1a;只使用交流電的正…

精選案例展 | 智己汽車—全棧可觀測驅動智能化運營與成本優化

本案例為“觀測先鋒 2024 可觀測平臺創新應用案例大賽”精選案例&#xff0c;同時榮獲IT168“2024技術卓越獎評選-年度創新解決方案”獎。 項目背景 近年來&#xff0c;中國汽車行業進入轉型升級階段&#xff0c;智能網聯技術成為行業發展的核心。車聯網、自動駕駛等技術的加速…