99热这里只有精品2-99热这里只有精品6免费-99热这里只有精品国产99-99热这里只有精品国产99热门精品-99热这里只有精品国产动漫

編程代碼
新聞詳情

十種常見排序算法動圖演示(一)

發布時間:2020-03-19 09:03:18 最后更新:2020-11-23 14:41:26 瀏覽次數:3467

0、算法概述

0.1 算法分類

十種常見排序算法可以分為兩大類:

  • 比較類排序:通過比較來決定元素間的相對次序,由于其時間復雜度不能突破O(nlogn),因此也稱為非線性時間比較類排序。
  • 非比較類排序:不通過比較來決定元素間的相對次序,它可以突破基于比較排序的時間下界,以線性時間運行,因此也稱為線性時間非比較類排序。 

0.2 算法復雜度

0.3 相關概念

  • 穩定:如果a原本在b前面,而a=b,排序之后a仍然在b的前面。
  • 不穩定:如果a原本在b的前面,而a=b,排序之后 a 可能會出現在 b 的后面。
  • 時間復雜度:對排序數據的總的操作次數。反映當n變化時,操作次數呈現什么規律。
  • 空間復雜度:是指算法在計算機

內執行時所需存儲空間的度量,它也是數據規模n的函數。 

1、冒泡排序(Bubble Sort)

冒泡排序是一種簡單的排序算法。它重復地走訪過要排序的數列,一次比較兩個元素,如果它們的順序錯誤就把它們交換過來。走訪數列的工作是重復地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個算法的名字由來是因為越小的元素會經由交換慢慢“浮”到數列的頂端。 

1.1 算法描述

  • 比較相鄰的元素。如果第一個比第二個大,就交換它們兩個;
  • 對每一對相鄰元素作同樣的工作,從開始第一對到結尾的最后一對,這樣在最后的元素應該會是最大的數;
  • 針對所有的元素重復以上的步驟,除了最后一個;
  • 重復步驟1~3,直到排序完成。

1.2 動圖演示

1.3 代碼實現


2、選擇排序(Selection Sort)

選擇排序(Selection-sort)是一種簡單直觀的排序算法。它的工作原理:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再從剩余未排序元素中繼續尋找最小(大)元素,然后放到已排序序列的末尾。以此類推,直到所有元素均排序完畢。 

2.1 算法描述

n個記錄的直接選擇排序可經過n-1趟直接選擇排序得到有序結果。具體算法描述如下:

  • 初始狀態:無序區為R[1..n],有序區為空;
  • 第i趟排序(i=1,2,3…n-1)開始時,當前有序區和無序區分別為R[1..i-1]和R(i..n)。該趟排序從當前無序區中-選出關鍵字最小的記錄 R[k],將它與無序區的第1個記錄R交換,使R[1..i]和R[i+1..n)分別變為記錄個數增加1個的新有序區和記錄個數減少1個的新無序區;
  • n-1趟結束,數組有序化了。

2.2 動圖演示

  

2.3 代碼實現

2.4 算法分析

表現最穩定的排序算法之一,因為無論什么數據進去都是O(n2)的時間復雜度,所以用到它的時候,數據規模越小越好。唯一的好處可能就是不占用額外的內存空間了吧。理論上講,選擇排序可能也是平時排序一般人想到的最多的排序方法了吧。

3、插入排序(Insertion Sort)

插入排序(Insertion-Sort)的算法描述是一種簡單直觀的排序算法。它的工作原理是通過構建有序序列,對于未排序數據,在已排序序列中從后向前掃描,找到相應位置并插入。

3.1 算法描述

一般來說,插入排序都采用in-place在數組上實現。具體算法描述如下:

  • 從第一個元素開始,該元素可以認為已經被排序;
  • 取出下一個元素,在已經排序的元素序列中從后向前掃描;
  • 如果該元素(已排序)大于新元素,將該元素移到下一位置;
  • 重復步驟3,直到找到已排序的元素小于或者等于新元素的位置;
  • 將新元素插入到該位置后;
  • 重復步驟2~5。

3.2 動圖演示

3.2 代碼實現

3.4 算法分析

插入排序在實現上,通常采用in-place排序(即只需用到O(1)的額外空間的排序),因而在從后向前掃描過程中,需要反復把已排序元素逐步向后挪位,為最新元素提供插入空間。

4、希爾排序(Shell Sort)

1959年Shell發明,第一個突破O(n2)的排序算法,是簡單插入排序的改進版。它與插入排序的不同之處在于,它會優先比較距離較遠的元素。希爾排序又叫縮小增量排序

4.1 算法描述

先將整個待排序的記錄序列分割成為若干子序列分別進行直接插入排序,具體算法描述:

  • 選擇一個增量序列t1,t2,…,tk,其中ti>tj,tk=1;
  • 按增量序列個數k,對序列進行k 趟排序;
  • 每趟排序,根據對應的增量ti,將待排序列分割成若干長度為m 的子序列,分別對各子表進行直接插入排序。僅增量因子為1 時,整個序列作為一個表來處理,表長度即為整個序列的長度。

4.2 動圖演示

4.3 代碼實現

4.4 算法分析

希爾排序的核心在于間隔序列的設定。既可以提前設定好間隔序列,也可以動態的定義間隔序列。動態定義間隔序列的算法是《算法(第4版)》的合著者Robert Sedgewick提出的。 


在線客服 雙翌客服
客服電話
  • 0755-23712116
  • 13310869691
主站蜘蛛池模板: 国产视频一区在线| 中国一级特黄毛片| 免费国产不卡午夜福在线观看| 国产二区精品视频| 国产成人cao在线| 国产免费一区二区| 国产精品自拍视频| 国产激情视频在线观看首页| 特黄录像| 国模私拍福利视频在线透漏| 美女mm翘臀后进式动态图| 黄网在线看| 高清一级做a爱免费视| 特级做人爱c级特级aav毛片| 黄色一级免费片| 特黄特色一级aa毛片免费观看| 高清影院在线欧美人色| 美日韩免费视频| 国精品日韩欧美一区二区三区| 国产精品三级在线播放| 国产酒店视频| 国产三级黄色片| 国内自拍在线视频高清| 欧美性爽xxxⅹbbbb| 欧美va在线高清| 色播日韩| 亚洲国产一区二区三区四区五区 | 欧美黄色片在线播放| 欧美黄色大全| 免费黄网在线观看| 成年超爽大片免费视频播放| 成人夜色| 风流慈禧一级毛片在线播放| 日本福利视频一区| 久久精品人| 99久久精品免费观看国产| 最新国产精品亚洲| 亚洲国产成人久久午夜| 日韩成人中文字幕| 久久本道久久综合伊人| 国产精品成人免费视频不卡|