亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 邏輯算法 > 正文

排序算法

2024-09-08 23:18:43
字體:
來源:轉載
供稿:網友

為什么有這么多的排序算法?

首先,在計算機編程中排序是一個經常遇到的問題。數據只有經過排序后,才更有意義。其次,排序算法說明了許多重要的算法的技術,例如二進制細分,遞歸和線性添加。最后要說明的一點是不同的算法有不同的優缺點,沒有一種算法在任何情況下都是最好的算法。

汽泡排序法

該算法是專門針對已部分排序的數據進行排序的一種排序算法。如果在你的數據清單中只有一兩個數據是亂序的話,用這種算法就是最快的排序算法。如果你的數據清單中的數據是隨機排列的,那么這種方法就成了最慢的算法了。因此在使用這種算法之前一定要慎重。

這種算法的核心思想是掃描數據清單,尋找出現亂序的兩個相鄰的項目。當找到這兩個項目后,交換項目的位置然后繼續掃描。重復上面的操作直到所有的項目都按順序排好。

圖1是對這種算法的說明。在該例中,數字1的未按順序排好。第一次掃描清單時,程序找到4和1是兩個相鄰的亂序項目,于是交換它們的位置。以此類推,直到將所有的項目按1234排好。數字1就象上升的汽泡一樣,這就是這一算法名稱的由來。

2221
3312
4133
1444
圖1.

你可以改進該算法,讓程序自下而上開始掃描,這樣只須一次就能排好順序了。

下面是用VB代碼實現這一算法的例子:

' min and max are the minimum and maximum indexes' of the items that might still be out of order.Sub BubbleSort (List() As Long, ByVal min As Integer, _    ByVal max As Integer)Dim last_swap As IntegerDim i As IntegerDim j As IntegerDim tmp As Long    ' Repeat until we are done.    Do While min < max        ' Bubble up.        last_swap = min - 1        ' For i = min + 1 To max        i = min + 1        Do While i <= max            ' Find a bubble.            If List(i - 1) > List(i) Then                ' See where to drop the bubble.                tmp = List(i - 1)                j = i                Do                    List(j - 1) = List(j)                    j = j + 1                    If j > max Then Exit Do                Loop While List(j) < tmp                List(j - 1) = tmp                last_swap = j - 1                i = j + 1            Else                i = i + 1            End If        Loop        ' Update max.        max = last_swap - 1        ' Bubble down.        last_swap = max + 1        ' For i = max - 1 To min Step -1        i = max - 1        Do While i >= min            ' Find a bubble.            If List(i + 1) < List(i) Then                ' See where to drop the bubble.                tmp = List(i + 1)                j = i                Do                    List(j + 1) = List(j)                    j = j - 1                    If j < min Then Exit Do                Loop While List(j) > tmp                List(j + 1) = tmp                last_swap = j + 1                i = j - 1            Else                i = i - 1            End If        Loop        ' Update min.        min = last_swap + 1    LoopEnd Sub

選擇排序法 選擇排序法是一個很簡單的算法。其原理是首先找到數據清單中的最小的數據,然后將這個數據同第一個數據交換位置;接下來找第二小的數據,再將其同第二個數據交換位置,以此類推。下面是VB代碼實現該算法。

Sub Selectionsort (List() As Long, min As Integer, _    max As Integer)Dim i As IntegerDim j As IntegerDim best_value As LongDim best_j As Integer    For i = min To max - 1        best_value = List(i)        best_j = i        For j = i + 1 To max            If List(j) < best_value Then                best_value = List(j)                best_j = j            End If        Next j        List(best_j) = List(i)        List(i) = best_value    Next iEnd Sub

當尋找第I小的數據時,你必須檢查N-I個項目,所以這一算法所用的步驟可用下面這個公式求得。

    N + (N - 1) + (N - 2) + ... + 1 = N * (N + 1) / 2

選擇排序法適用于較少數據的排序。此外由于算法較簡單,因此他的代碼也比較簡單,這就為我們維護代碼帶來了方便。實際上如果你的數據相當少的話,這種算法的速度快過其它更復雜的算法。

快速排序法

快速排序法對于大量數據的排序特別有用。其基本原理是:首先檢查數據列表中的數據數,如果小于兩個,則直接退出程序。如果有超過兩個以上的數據,就選擇一個分割點將數據分成兩個部分,小于分割點的數據放在一組,其余的放在另一組,然后分別對兩組數據排序。

通常分割點的數據是隨機選取的。這樣無論你的數據是否已被排列過,你所分割成的兩個字列表的大小是差不多的。而只要兩個子列表的大小差不多,該算法所需的步驟就是N * log(N) 步。對于使用比較法進行排序的算法來講這是最快的方法。下面是用VB代碼實現這一算法的例子。

Sub Quicksort (List() As Long, min As Integer, max As Integer)Dim med_value As LongDim hi As IntegerDim lo As IntegerDim i As Integer    ' If the list has no more than 1 element, it's sorted.    If min >= max Then Exit Sub    ' Pick a dividing item.    i = Int((max - min + 1) * Rnd + min)    med_value = List(i)    ' Swap it to the front so we can find it easily.    List(i) = List(min)    ' Move the items smaller than this into the left    ' half of the list. Move the others into the right.    lo = min    hi = max    Do        ' Look down from hi for a value < med_value.        Do While List(hi) >= med_value            hi = hi - 1            If hi <= lo Then Exit Do        Loop        If hi <= lo Then            List(lo) = med_value            Exit Do        End If        ' Swap the lo and hi values.        List(lo) = List(hi)                ' Look up from lo for a value >= med_value.        lo = lo + 1        Do While List(lo) < med_value            lo = lo + 1            If lo >= hi Then Exit Do        Loop        If lo >= hi Then            lo = hi            List(hi) = med_value            Exit Do        End If        ' Swap the lo and hi values.        List(hi) = List(lo)    Loop    ' Sort the two sublists    Quicksort List(), min, lo - 1    Quicksort List(), lo + 1, maxEnd Sub

計數排序法

前面提到過,對于使用比較法作為算法基礎的算法來說,最快需N * log(N)步才能完成排序。計數排序法不作用比較,所以它不受此限制。實際上該算法是如此之快,以致于你會認為是使用了魔術,而不是數學運算來排序。

另一方面,計數排序法只能用于特殊的情況。首先,所有的要進行排序的數據必須是整數,不能對字符使用該算法;其次,數據的范圍有限,如果你的數據是在1到1000之內,用這種算法的效果就非常好,但如果你的數據是在1到30000之間,該算法就根本不能用。

首先該算法創建一個整數類型的臨時數組,該數組的上下標分別是要排序的數據的最大最小值。如果數據列表的最大最小值從min_item到max_item, 該算法就將數組創建成下面這樣:

    Dim Counts() As Integer    ReDim Counts(min_item To max_item)
接下來,算法檢查列表中的每一個項目,并增加對應該項目的數組元素的值,當這一階段完成后,Counts(I)的數值就是就是數值為I的基礎上的個數。
    For I = min To Max        Counts(List(I)) = Counts(List(I)) + 1    Next I
程序掃描Counts數組,將counts轉換成被排序列表中的偏移量。
    next_spot = 1    For i = min_value To max_value        this_count = counts(i)        counts(i) = next_spot        next_spot = next_spot + this_count    Next i
最后將數據進行排序

下面是實現該算法的VB代碼

Sub Countingsort (List() As Long, sorted_list() As Long, _    min As Integer, max As Integer, min_value As Long, _    max_value As Long)Dim counts() As IntegerDim i As IntegerDim this_count As IntegerDim next_offset As Integer    ' Create the Counts array.    ReDim counts(min_value To max_value)    ' Count the items.    For i = min To max        counts(List(i)) = counts(List(i)) + 1    Next i    ' Convert the counts into offsets.    next_offset = min    For i = min_value To max_value        this_count = counts(i)        counts(i) = next_offset        next_offset = next_offset + this_count    Next i    ' Place the items in the sorted array.    For i = min To max        sorted_list(counts(List(i))) = List(i)        counts(List(i)) = counts(List(i)) + 1    Next iEnd Sub

總結

下表是各種算法的優缺點比較,正如你所見到的那樣,每種算法只是在某一情況下表現得最好,下面是選擇算法時的一些原則:

  • 如果你的數據列表中有99%數據已排過序,則用汽泡排序法。
  • 如果你要排序的數據較少(100個以下),則用選擇排序法。
  • 如果你的數據都是整數,并且數值不大(幾千以內),則用計數排序法。
  • 否則的話用快速排序法法
算法優點缺點
汽泡排序法對以初步排序的數據來說這種方法的速度很快在其它情況下運行速度較慢
選擇排序法非常簡單對大量數據的排序速度很慢
容易明白
對于少量數據的排序來說速度很快
快速排序法對大量數據的排序來說速度很快如果有大量重復的數據就比較麻煩
計數排序法當數據數值較小(1-1000之間)時,速度非???/TD>當數據數值較大時,速度較慢
需額外的內存
只能對整數類型的數據排序
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩精品在线观| 亚洲欧美一区二区三区情侣bbw| 日韩av第一页| 久久久精品2019中文字幕神马| 成人两性免费视频| 亚洲精品成人久久| 亚洲国产一区二区三区四区| 亚洲天堂av高清| 久久久久久网址| 久久久精品免费视频| 亚洲精品一区中文字幕乱码| 久久久免费观看| 欧美国产日产韩国视频| 在线看片第一页欧美| 91精品在线播放| 国内精久久久久久久久久人| 亚洲女人天堂网| 欧美午夜视频在线观看| 久久99精品国产99久久6尤物| 国产美女搞久久| 97av视频在线| 国产日韩精品在线观看| 日本亚洲欧洲色α| 亚洲精品视频播放| 国内免费精品永久在线视频| 国产一区二区黑人欧美xxxx| 91亚洲精品久久久久久久久久久久| 热久久视久久精品18亚洲精品| 亚洲国产精品人人爽夜夜爽| 91精品国产综合久久久久久久久| 国产精品视频精品视频| 日韩电影中文字幕在线| 亚洲欧洲日产国产网站| 日韩av在线天堂网| 性欧美暴力猛交69hd| 精品国产自在精品国产浪潮| 国产欧美精品在线| 97在线视频免费看| 欧美日韩国产综合新一区| 欧美激情精品久久久久久免费印度| 8090理伦午夜在线电影| 亚洲女同精品视频| 日韩欧美a级成人黄色| 国产精品久久久久国产a级| 国产精品福利网| 欧美在线性视频| 亚洲美女黄色片| 欧美做受高潮1| 国产精品美女www爽爽爽视频| 热re91久久精品国99热蜜臀| 亚洲欧美一区二区三区四区| 欧美日韩国产va另类| 热99精品里视频精品| 亚洲第五色综合网| 欧美黄色www| 国产69精品99久久久久久宅男| 亚洲**2019国产| 伊人久久五月天| 日韩av在线看| 欧美日韩一二三四五区| 欧美国产日韩在线| 欧美激情亚洲综合一区| 人人爽久久涩噜噜噜网站| 日韩视频在线免费| 国产精品视频公开费视频| 日日摸夜夜添一区| 亚洲欧美制服丝袜| 亚洲综合一区二区不卡| 欧美激情精品久久久久久蜜臀| 日韩毛片在线观看| 91精品国产高清自在线| 国产成人av网址| 自拍偷拍免费精品| 精品国产91久久久久久| 国产性色av一区二区| 91久久久久久久久| 日本高清视频精品| 欧美日韩国产限制| 国产一区视频在线播放| 欧美专区在线播放| 久久久影视精品| 日韩中文理论片| 日韩国产精品视频| 欧美激情二区三区| 超薄丝袜一区二区| 久久综合网hezyo| 日韩精品视频在线播放| 在线激情影院一区| 亚洲天堂免费视频| 亚洲国产成人爱av在线播放| 久久综合电影一区| 激情成人中文字幕| 98午夜经典影视| 川上优av一区二区线观看| 久久躁日日躁aaaaxxxx| 日韩av电影在线免费播放| 国产精品偷伦视频免费观看国产| 久久精品国产亚洲精品| 国产99久久精品一区二区| 国产精品第七十二页| 国产精品夜色7777狼人| 欧美另类69精品久久久久9999| 国产日韩精品一区二区| 57pao成人国产永久免费| 欧美亚洲另类在线| 91精品中国老女人| 九九九热精品免费视频观看网站| 欧美成人免费va影院高清| 久久中文字幕视频| 国产在线播放不卡| www.欧美三级电影.com| 在线观看精品国产视频| 亚洲片在线资源| 国产综合久久久久久| 亚洲成人三级在线| 美女久久久久久久| 成人久久18免费网站图片| 欧美性感美女h网站在线观看免费| 亚洲国产另类 国产精品国产免费| 欧美激情啊啊啊| 日韩小视频在线观看| 日韩激情av在线播放| 日韩av中文字幕在线| 欧美一区二区三区图| 欧美放荡办公室videos4k| 国产精品久久999| 国外视频精品毛片| 欧美成人激情图片网| 日韩一区二区三区国产| 66m—66摸成人免费视频| 欧美激情18p| 操91在线视频| 久久影院免费观看| 久久久www成人免费精品张筱雨| 成人福利网站在线观看11| 精品国偷自产在线| 国产日韩在线亚洲字幕中文| 伊人亚洲福利一区二区三区| 国产在线精品一区免费香蕉| 伊人久久五月天| 亚洲国产欧美一区二区三区久久| 国模极品一区二区三区| 亚洲3p在线观看| 亚洲性生活视频在线观看| 欧美另类99xxxxx| 日韩有码在线电影| 国产成人精品免费久久久久| 51色欧美片视频在线观看| 日韩av一卡二卡| 欧美激情一区二区三区成人| 69久久夜色精品国产69乱青草| 欧美激情亚洲自拍| 色哟哟网站入口亚洲精品| 日韩精品高清在线| 日韩毛片中文字幕| 亚洲欧美第一页| 午夜精品久久久久久99热软件| 97超碰蝌蚪网人人做人人爽| 伊人久久五月天| 黄网动漫久久久| 在线看片第一页欧美| 亚洲va码欧洲m码| 78m国产成人精品视频| 91产国在线观看动作片喷水|