欧美日韩在线第一页-欧美日韩在线观看精品-欧美日韩在线观看一区二区-欧美日韩在线免费看-欧美日韩在线视频不卡一区二区三区

編程代碼
新聞詳情

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

發(fā)布時間:2020-03-19 09:03:18 最后更新:2020-11-23 14:41:26 瀏覽次數(shù):3088

0、算法概述

0.1 算法分類

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

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

0.2 算法復雜度

0.3 相關概念

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

內執(zhí)行時所需存儲空間的度量,它也是數(shù)據(jù)規(guī)模n的函數(shù)。 

1、冒泡排序(Bubble Sort)

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

1.1 算法描述

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

1.2 動圖演示

1.3 代碼實現(xiàn)


2、選擇排序(Selection Sort)

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

2.1 算法描述

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

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

2.2 動圖演示

  

2.3 代碼實現(xiàn)

2.4 算法分析

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

3、插入排序(Insertion Sort)

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

3.1 算法描述

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

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

3.2 動圖演示

3.2 代碼實現(xiàn)

3.4 算法分析

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

4、希爾排序(Shell Sort)

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

4.1 算法描述

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

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

4.2 動圖演示

4.3 代碼實現(xiàn)

4.4 算法分析

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


在線客服 雙翌客服
客服電話
  • 0755-23712116
  • 13822267203
主站蜘蛛池模板: 日韩精品久久久久影院| 毛片线看免费观看| 91亚洲视频在线观看| 精品国产香蕉在线播出| 国产美女在线观看| 毛片啪啪啪| 香蕉视频好色先生| 精品一区二区三区水蜜桃| 免费a在线看| 97视频在线视频| 国产美女挤奶水在线观看| 国产一级自拍| 不卡的| 亚洲 欧美 自拍 另类 欧美| 97青青草原国产免费观看| 欧美日批视频| 小色片| 九九爱国产| 国产成人一区在线播放| 日本在线看片网站| 免费影院| 特级黄色毛片| 亚洲精品美女国产一区| 91精品免费观看| 国产精品成人免费综合| 欧美成人性高清观看| 日本黄色免费大片| 欧美二级在线观看免费| 国产精品区一区二区三| 中国一级做a爱片免费| 日韩欧美黄色| 国产精品第8页| 中文字幕日本一区久久| 青草国产视频| 国产精品亚洲欧美| 日韩欧美一区二区三区在线播放| 青青青国产在线手机免费观看| 国产精选一区| 日韩国产免费一区二区三区| 欧美在线第一二三四区| 国产精品久久久久久久久久久久久久|