6.比較排序之快速排序

来源:http://www.cnblogs.com/yulinfeng/archive/2017/06/27/7083059.html
-Advertisement-
Play Games

快速排序(簡稱快排)因為其效率較高(平均O(nlogn))經常在筆試題中對其考查。 對於快排的第一步是選取一個“基數”,將會用這個“基數”與其它數進行比較交換。而這個“基數”的選擇將影響到快排的效率如何,但如果為了選擇基數而選擇基數則會本末倒置。例如為了找到最佳基數,則需要在整個待排序列中找到中位數 ...


  快速排序(簡稱快排)因為其效率較高(平均O(nlogn))經常在筆試題中對其考查。

  對於快排的第一步是選取一個“基數”,將會用這個“基數”與其它數進行比較交換。而這個“基數”的選擇將影響到快排的效率如何,但如果為了選擇基數而選擇基數則會本末倒置。例如為了找到最佳基數,則需要在整個待排序列中找到中位數,但查找中位數實際上代價又會很高。基數的選擇通常來說就是待排序序列中的第一個對象或者中間的一個對象或者最後一個對象。本文以選取第一個元素為例對快排做一個簡要分析實現。

  以待排序列{6, 5, 3, 1, 7, 2, 4}為例,選取第一個元素6為基數。

  選擇了基數過後則需要進行和數組元素進行比較交換,如何進行比較和誰進行比較?快排第二步在數組的第一個元素和最後元素各設置一個“哨兵”。

  選好基數,設置好哨兵過後,接下來則是開始比較,將基數先與最後一個哨兵j進行比較,如果大於哨兵j則與其進行交換同時哨兵i+1

  此時基數不再與哨兵j進行比較,而是與哨兵i進行比較,如果基數大於哨兵i,則哨兵一直向後移,直到大於基數為止交換同時哨兵j-1。

  重覆上面的步驟,基數再與哨兵j比較。

  最終結果可見哨兵i的位置=哨兵j的位置,此時將基數賦值給這個位置。

  這樣就達到了基數6左邊的數字均小於它,右邊的數字均大於它,再利用遞歸對其左右數組進行同樣的步驟選取基數,設置哨兵,最後即可完成排序。

  Java

 1 package com.algorithm.sort.quick;
 2 
 3 import java.util.Arrays;
 4 
 5 /**
 6  * 快速排序
 7  * Created by yulinfeng on 2017/6/26.
 8  */
 9 public class Quick {
10     public static void main(String[] args) {
11         int[] nums = {6, 5, 3, 1, 7, 2, 4};
12         nums = quickSort(nums, 0, nums.length - 1);
13         System.out.println(Arrays.toString(nums));
14     }
15     
16     /**
17      * 快速排序
18      * @param nums 待排序數組序列
19      * @param left 數組第一個元素索引
20      * @param right 數組最後一個元素索引
21      * @return 排好序的數組序列
22      */
23     private static int[] quickSort(int[] nums, int left, int right) {
24         if (left < right) {
25             int temp = nums[left];    //基數
26             int i = left;    //哨兵i
27             int j = right;    //哨兵j
28             while (i < j) {
29                 while (i < j && nums[j] >= temp) {
30                     j--;
31                 }
32                 if (i < j) {
33                     nums[i] = nums[j];
34                     i++;
35                 }
36                 while (i < j && nums[i] < temp) {
37                     i++;
38                 }
39                 while (i < j) {
40                     nums[j] = nums[i];
41                     j--;
42                 }
43             }
44             nums[i] = temp;
45             quickSort(nums, left, i - 1);
46             quickSort(nums, i + 1, right);
47         }
48         return nums;
49     }
50 }

  Python3

 1 #快速排序
 2 def quick_sort(nums, left, right):
 3     if left < right:
 4         temp = nums[left]    #基數
 5         i = left    #哨兵i
 6         j = right    #哨兵j
 7         while i < j:
 8             while i < j and nums[j] >= temp:
 9                 j -= 1
10             if i < j:
11                 nums[i] = nums[j]
12                 i += 1
13             while i < j and nums[i] < temp:
14                 i += 1
15             if i < j:
16                 nums[j] = nums[i]
17                 j -= 1
18         nums[i] = temp
19         quick_sort(nums, left, i - 1)
20         quick_sort(nums, i + 1, right)
21     
22     return nums
23 
24 nums = [6, 5, 3, 1, 7, 2, 4]
25 nums = quick_sort(nums, 0, len(nums) - 1)
26 print(nums)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、獲取Tag 1.find_all方法 (1)find_all(name='tag_name',attrs,recursive,text,**kwargs) name:tag對應的名稱,當包括多個tag時,返回的是一個列表,可以利用列表功能選取對應的tag。 href:tag的屬性,常用屬性cla ...
  • 1 html_doc = "" 2 sp = BeautifulSoup(html_doc,"html.parser") 3 print(sp.p['class']) 4 #['body','strikeout'] 5 print(sp.p['id']) 6 #zhangsan 7 8 html_d... ...
  • 課程中詳細演示了一個應用從單塊架構到垂直應用架構再到分散式服務架構的演進過程。講解瞭如何在前後端分離的架構下設計RESTful API。最終的系統對外提供REST風格的http服務,內部各個垂直應用通過dubbo共用無狀態的Java服務。整個系統在Web層和服務層都可以無縫的橫向擴展。 ...
  • 抓取內容: 從最好大學網上抓取中國前10的大學排名、大學名稱、總分,並數據格式左對齊。 http://www.zuihaodaxue.cn/zuihaodaxuepaiming2017.html 首先,看下網站的Robots協議,沒有找到相關協議,可以抓取。 http://www.zuihaodax ...
  • var a,f:array[1..10000000] of longint; b,i,j,n,s,x,y:longint;begin read(b,n); for i:=1 to n do a[i]:=0; for i:=1 to n do begin readln(x,y); a[x]:=1-a[ ...
  • 什麼是進程(process)? 程式並不能單獨運行,只有將程式裝載到記憶體中,系統為它分配資源才能運行,而這種執行的程式就稱之為進程。程式和進程的區別就在於,程式是指令的集合,它是進程運行的靜態描述文本;進程是程式的一次執行活動,屬於動態概念。 什麼是線程(thread)? 線程是操作系統能夠進行運算... ...
  • 想知道怎麼用python處理尾碼為".sqlite"的文件,這裡有你想要的答案。 ...
  • /* 標識對象模式 這個模式主要功能就是創建sql語句中的wehre條件字元串的,下麵直接看代碼和註釋: */ namespace woo\mapper; //欄位對象 class Field { protected $name = null; //欄位名稱 protected $operator ... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...