算法復習——6種排序方法的簡單回顧

算法復習——6種排序方法的簡單回顧

常見排序方法:冒泡排序、選擇排序、插入排序、堆排序、歸并排序、快速排序的簡單回顧

冒泡排序

重復“從序列右邊開始比較相鄰兩個數字的大小,再根據結果交換兩個數字的位置”

在這里插入圖片描述

在冒泡排序中,第 1 輪需要比較 n - 1 次,第 2 輪需要比較 n - 2 次…第 n - 1 輪需要比較 1 次。因此,總的比較次數為 (n - 1) + (n - 2) + … + 1≈n2/2。

時間復雜度:O(n2)

選擇排序

重復“從待排序的數據中尋找最小值,將其與序列最左邊的數字進行交換”

在這里插入圖片描述

使用線性查找在數據中尋找最小值,找到最小值1。(詳見下一篇文章:數組的查找:線性查找,二分查找)

與最左端數字6交換,即可完成此次操作。

在余下的數字中尋找最小值,重復以上操作:

在這里插入圖片描述

比較次數:(n - 1) + (n - 2) + … + 1≈n2/2 次

時間復雜度:O(n2)

插入排序

從序列左端開始依次對數據進行排序。插入排序的思路就是從右側的未排序區域內取出一個數據,然后將它插入到已排序區域內合適的位置上。

在這里插入圖片描述

首先先排好5在第一個位置。從待排數字(未排序區域)中取出最左邊的數字 3,將它與左邊已歸位的數字進行比較。若左邊的數字更大,就交換這兩個數字。重復該操作,直到左邊已歸位的數字比取出的數字更小,或者取出的數字已經被移到整個序列的最左邊為止。

時間復雜度:O(n2)

堆排序

利用了數據結構中的堆。關于堆的介紹可以見上一章:數據結構復習-CSDN博客

在這里插入圖片描述

首先,在堆中存儲所有的數據,并按降序來構建堆。

在這里插入圖片描述

取出第一個數字后,重新構造堆。

重復上述操作直到堆變空為止。

在這里插入圖片描述

時間復雜度:O(nlogn)

雖然運行時間短,但數據結構相對復雜,實現起來相對困難。

歸并排序

把序列分成長度相同的兩個子序列,當無法繼續往下分時(也就是每個子 序列中只有一個數據時),就對子序列進行歸并。

歸并:把兩個排好序的子序列合并成一個有序序列。

在這里插入圖片描述

在這里插入圖片描述

將序列逐次分割。分割完畢后,按從小到大順序合并。

在這里插入圖片描述

合并這種含有多個數字的子序列時,要先比較首位數字,再移動較小的數字。

在這里插入圖片描述

歸并排序中,分割序列所花費的時間不算在運行時間內(可以當作序列本來就是分割好的)

無論哪一行都是n個數據,所以每行的運行時間都為 O(n)。而將長度為 n 的序列對半分割直到只有一個數據為止時,可以分成 log2n 行。

時間復雜度:O(nlogn)

快速排序

首先會在序列中隨機選擇一個基準值(pivot),然后將除了基準值以外的數分為“比基準值小的數”和“比基準值大的數”這兩個類別,再將其排列成以下形式。

[ 比基準值小的數 ] 基準值 [ 比基準值大的數 ]

接著,對兩個“[ ]”中的數據進行排序之后,整體的排序便完成了。對“[ ]”里面的數據進行排序時同樣也會使用快速排序。

在這里插入圖片描述

舉例:隨機取4為基準值。將其他數字和基準值進行比較。小于基準值的往左移,大于基準值的往右移。

在這里插入圖片描述

完成后,再分別對左邊和右邊的數據進行快速排序,就能完成整體的排序。

快速排序是一種**“分治法”**。它將原本的問題分成兩個子問題(比基準值小的數和比基準值大的數),然后再分別解決這兩個問題。

像這樣,在算法內部繼續使用該算法的現象被稱為**“遞歸”**。

時間復雜度:O(nlogn)(如果數據中的每個數字被選為基準值的概率都相等,平均運行時間)

參考資料:我的第一本算法書 (石田保輝 宮崎修一)

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

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

相關文章

Tair(1):Tair介紹

1 介紹 ? 在Tair出現之前的很長一段時間里,像redis、memcache這些知名NoSql數據庫是不支持分布式的,在這樣的背景下,由淘寶網自主開發并在2010.6開源的一個高性能、高擴展、高可靠分布式緩存,類似map的key/value結構&#xff0c…

使用單例模式+觀察者模式實現參數配置實時更新

使用vector存儲觀察者列表 #include <iostream> #include <vector> #include <functional> #include <algorithm>// 配置參數結構體 struct MyConfigStruct {int parameter1;std::string parameter2; };class Config { public:using Observer std::f…

hive 命令行中使用 replace 和nvl2 函數報錯

1.有時候在命令行的情況下使用 replace 函數時會報錯 這個時候可以使用 translate 代替 2.有時候使用 nvl2() 函數的時候會報錯 這個時候可以用 case when 來代替

【Spring 源碼】 深入理解 Bean 定義之 BeanDefinition

&#x1f680; 作者主頁&#xff1a; 有來技術 &#x1f525; 開源項目&#xff1a; youlai-mall &#x1f343; vue3-element-admin &#x1f343; youlai-boot &#x1f33a; 倉庫主頁&#xff1a; Gitee &#x1f4ab; Github &#x1f4ab; GitCode &#x1f496; 歡迎點贊…

兩數之和問題

更好的閱讀體驗請點擊 兩數之和。 題目&#xff1a;兩數之和 ? 給定一個整數數組 nums 和一個整數目標值 target&#xff0c;請你在該數組中找出 和為目標值 target 的那 兩個 整數&#xff0c;并返回它們的數組下標。 ? 你可以假設每種輸入只會對應一個答案。但是&#xff…

MetricBeat監控Redis

目錄 一、安裝部署 二、開啟Redis監控模塊 三、編輯Redis配置文件 四、啟動Metricbeat 五、查看監控圖表 一、安裝部署 metriceat的安裝部署參考章節&#xff1a; 監控組件>Metricbeat安裝使用&#xff0c;這里不再贅述。 二、開啟Redis監控模塊 進入metricbeat安裝目錄…

【每日一題】出租車的最大盈利

文章目錄 Tag題目來源解題思路方法一&#xff1a;遞歸方法二&#xff1a;遞歸記錄數組記憶化搜索方法三&#xff1a;動態規劃&#xff08;遞推&#xff09; 寫在最后 Tag 【遞歸】【記憶化搜索】【動態規劃】【數組】【2023-12-08】 題目來源 2008. 出租車的最大盈利 解題思路…

【EI會議征稿中】2024年第四屆人工智能、自動化與高性能計算國際會議(AIAHPC 2024)

2024年第四屆人工智能、自動化與高性能計算國際會議&#xff08;AIAHPC 2024&#xff09; 2024 4th International Conference on Artificial Intelligence, Automation and High Performance Computing 2024第四屆人工智能、自動化與高性能計算國際會議(AIAHPC 2024)將于20…

藍橋杯從零開始備戰(Python組)---基礎知識篇

第一次嘗試報名藍橋杯的Python組&#xff0c;好好備戰&#xff0c;希望省賽可以拿獎&#xff01;目前是整理了一些Python的常用函數和常用內置庫&#xff0c;后面可能會開始刷題&#xff0c;如果有比較需要記住的知識點&#xff0c;會再寫一篇刷題篇 一、輸入輸出 1.輸入字符…

游戲被攻擊怎么辦

隨著科技的進步和互聯網的普及&#xff0c;游戲行業也正在經歷前所未有的變革。玩家們不再滿足于傳統的線下游戲&#xff0c;而是轉向了線上游戲。然而&#xff0c;隨著游戲的線上化&#xff0c;游戲安全問題也日益凸顯。游戲受到攻擊是游戲開發者永遠的痛點&#xff0c;談“D“…

HomeAssistant添加HACS插件并實現公網控制米家,HomeKit等智能家居

HomeAssistant添加HACS插件并實現公網控制米家&#xff0c;HomeKit等智能家居 文章目錄 HomeAssistant添加HACS插件并實現公網控制米家&#xff0c;HomeKit等智能家居基本條件一、下載HACS源碼二、添加HACS集成三、綁定米家設備 ? 上文介紹了如何實現群暉Docker部署HomeAssist…

【嵌入式開發 Linux 常用命令系列 4.1 -- git push 遠程分支與本地分支查看】

文章目錄 概述git push 語法步驟1&#xff1a;git 遠程主機名查看步驟2&#xff1a;git 遠程分支名查看步驟3&#xff1a;git 本地分支名查看示例演示 概述 在日常工作中&#xff0c;將代碼 git clone 本地之后&#xff0c;或者使用repo init && repo sync 之后不知道…

SQLserver截取字符串

當我們存的數據是json的時候可以全部取出在模糊查詢但是有多個重復數據的時候就沒辦法準確的模糊出來這個時候我們就需要用的字符串截取 --創建函數create FUNCTION [dbo].[Fmax] (str varchar(50),start VARCHAR(50),length VARCHAR(50)) RETURNS varchar(max) AS BEGINDEC…

商品詳情頁評論和評論列表評論的排序html代碼

以下是一個簡單的商品詳情頁的 HTML 代碼示例&#xff1a; <!DOCTYPE html> <html> <head><title>商品詳情頁</title><style>/* CSS 樣式可以在這里添加 */</style> </head> <body><h1>商品詳情頁</h1><…

7-1 查找書籍

給定n本書的名稱和定價&#xff0c;本題要求編寫程序&#xff0c;查找并輸出其中定價最高和最低的書的名稱和定價。 輸入格式: 輸入第一行給出正整數n&#xff08;<10&#xff09;&#xff0c;隨后給出n本書的信息。每本書在一行中給出書名&#xff0c;即長度不超過30的字…

條碼生成器與Zint使用

文章目錄 目的條形碼zint支持條形碼種類下載編譯qt pro配置code保存條形碼目的 1: 了解條形碼數據理論知識 2: 了解zint第三方庫相關, 如何編譯引用到項目中 條形碼 條形碼(Barcode)一維碼 和二維碼(QR code)都是用于存儲信息的圖形化表示方式,通常應用于商品標識、庫…

無頭瀏覽器與Selenium:探索無界爬蟲的奇妙世界

selenium設置無頭瀏覽器 背景 ? 我們之前的selenium都是瀏覽器驅動自動打開一個網頁&#xff0c;執行相關操作&#xff0c;其實也可以讓其后臺顯示&#xff0c;不用在前臺顯示。 ? 要設置無頭瀏覽器&#xff0c;可以使用Selenium的Headless模式。在Headless模式下&#xf…

鴻蒙(HarmonyOS)應用開發——web組件

簡述 在開發的工作中&#xff0c;可能存在一個場景&#xff0c;我們有一個問卷調查的h5頁面&#xff0c;需要切入到app 中。這個時候&#xff0c;就需要從app 端操作&#xff0c;切換到web端操作。不管是安卓、ios、小程序都提供有web組件。那么harmonyos 中也提供web組件來在…

Kafka中的Topic

在Kafka中&#xff0c;Topic是消息的邏輯容器&#xff0c;用于組織和分類消息。本文將深入探討Kafka Topic的各個方面&#xff0c;包括創建、配置、生產者和消費者&#xff0c;以及一些實際應用中的示例代碼。 1. 介紹 在Kafka中&#xff0c;Topic是消息的邏輯通道&#xff0…

【華為數據之道學習筆記】3-2 基礎數據治理

基礎數據用于對其他數據進行分類&#xff0c;在業界也稱作參考數據。基礎數據通常是靜態的&#xff08;如國家、幣種&#xff09;&#xff0c;一般在業務事件發生之前就已經預先定義。它的可選值數量有限&#xff0c;可以用作業務或IT的開關和判斷條件。當基礎數據的取值發生變…