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

首頁 > 學(xué)院 > 邏輯算法 > 正文

排序算法

2024-09-08 23:18:43
字體:
供稿:網(wǎng)友

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

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

汽泡排序法

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

這種算法的核心思想是掃描數(shù)據(jù)清單,尋找出現(xiàn)亂序的兩個(gè)相鄰的項(xiàng)目。當(dāng)找到這兩個(gè)項(xiàng)目后,交換項(xiàng)目的位置然后繼續(xù)掃描。重復(fù)上面的操作直到所有的項(xiàng)目都按順序排好。

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

2221
3312
4133
1444
圖1.

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

下面是用VB代碼實(shí)現(xiàn)這一算法的例子:

' 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

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

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

當(dāng)尋找第I小的數(shù)據(jù)時(shí),你必須檢查N-I個(gè)項(xiàng)目,所以這一算法所用的步驟可用下面這個(gè)公式求得。

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

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

快速排序法

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

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

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

計(jì)數(shù)排序法

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

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

首先該算法創(chuàng)建一個(gè)整數(shù)類型的臨時(shí)數(shù)組,該數(shù)組的上下標(biāo)分別是要排序的數(shù)據(jù)的最大最小值。如果數(shù)據(jù)列表的最大最小值從min_item到max_item, 該算法就將數(shù)組創(chuàng)建成下面這樣:

    Dim Counts() As Integer    ReDim Counts(min_item To max_item)
接下來,算法檢查列表中的每一個(gè)項(xiàng)目,并增加對(duì)應(yīng)該項(xiàng)目的數(shù)組元素的值,當(dāng)這一階段完成后,Counts(I)的數(shù)值就是就是數(shù)值為I的基礎(chǔ)上的個(gè)數(shù)。
    For I = min To Max        Counts(List(I)) = Counts(List(I)) + 1    Next I
程序掃描Counts數(shù)組,將counts轉(zhuǎn)換成被排序列表中的偏移量。
    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
最后將數(shù)據(jù)進(jìn)行排序

下面是實(shí)現(xiàn)該算法的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

總結(jié)

下表是各種算法的優(yōu)缺點(diǎn)比較,正如你所見到的那樣,每種算法只是在某一情況下表現(xiàn)得最好,下面是選擇算法時(shí)的一些原則:

  • 如果你的數(shù)據(jù)列表中有99%數(shù)據(jù)已排過序,則用汽泡排序法。
  • 如果你要排序的數(shù)據(jù)較少(100個(gè)以下),則用選擇排序法。
  • 如果你的數(shù)據(jù)都是整數(shù),并且數(shù)值不大(幾千以內(nèi)),則用計(jì)數(shù)排序法。
  • 否則的話用快速排序法法
算法優(yōu)點(diǎn)缺點(diǎn)
汽泡排序法對(duì)以初步排序的數(shù)據(jù)來說這種方法的速度很快在其它情況下運(yùn)行速度較慢
選擇排序法非常簡(jiǎn)單對(duì)大量數(shù)據(jù)的排序速度很慢
容易明白
對(duì)于少量數(shù)據(jù)的排序來說速度很快
快速排序法對(duì)大量數(shù)據(jù)的排序來說速度很快如果有大量重復(fù)的數(shù)據(jù)就比較麻煩
計(jì)數(shù)排序法當(dāng)數(shù)據(jù)數(shù)值較小(1-1000之間)時(shí),速度非???/TD>當(dāng)數(shù)據(jù)數(shù)值較大時(shí),速度較慢
需額外的內(nèi)存
只能對(duì)整數(shù)類型的數(shù)據(jù)排序
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国内精品模特av私拍在线观看| 最新国产在线视频| 91九色鹿精品国产综合久久香蕉| 国产黄色片在线观看| 欧美黑人性猛交| 五月综合激情婷婷六月色窝| 亚洲欧美国产va在线影院| 在线观看不卡一区| 久久久久99精品成人片三人毛片| 夜夜嗨av一区二区三区中文字幕| 黄网在线免费| 色综合天天爱| gay网站在线| 少妇av一区二区三区| 国产精品白丝av嫩草影院| 中文字幕中文字幕一区三区| 亚洲一级淫片| 99视频入口| 成人精品一区二区三区中文字幕| 亚洲精品久久久久久久蜜桃臀| 亚洲国产综合久久精品小蝴蝶| 国产黄色片视频| 在线免费观看中文字幕| 成人性生交大片免费网站| 久久综合久中文字幕青草| 亚洲一区视频在线观看视频| 精品综合在线| 日韩a级在线观看| 久久一夜天堂av一区二区三区| 国产日产高清欧美一区二区三区| 日本在线一二三| 亚洲美女网站| 国产人成亚洲第一网站在线播放| 豆国产96在线|亚洲| jizzjizz在线| 久久综合精品一区| 日韩欧美在线视频免费观看| 久久青青色综合| 视频一区视频二区视频三区视频四区国产| 好妞色妞国产在线视频| 欧美在线视频一二三| 成人性生交免费看| 人人狠狠综合久久亚洲| 日本少妇xxxx动漫| 国内精品久久久久久久| 国产中文在线观看| 欧美黄页在线免费观看| 久久福利在线| 中文字幕一区二区三区乱码不卡| 人猿泰山h版在线观看| 在线观看欧美成人| 中文字幕亚洲精品乱码| 亚洲AV成人无码精电影在线| 天天色天天操天天| 丰满少妇又爽又紧又丰满电影| 年轻的保姆91精品| 日韩av综合网| 在线观看a网站| 国精产品一区一区三区mba视频| 欧美老女人性开放| 成人网18免费网站| 亚洲精品在线观看网站| 超碰在线播放91| av在线dvd| 欧美成人精品免费| 成人免费毛片a| 成人免费在线视频观看| 国产精品一二区| 国产精品永久入口久久久| 91亚洲资源网| 性一交一乱一色一视频麻豆| 日本性爱视频在线观看| 日本aⅴ大伊香蕉精品视频| 性欧美成人播放77777| 日韩网站在线免费观看| 亚洲高清视频在线| 2020日本在线视频中文字幕| 成人精品免费视频| 欧美性受xxxx黑人xxxx| 日韩电影在线观看中文字幕| 国产精品对白久久久久粗| 亚洲在线视频免费观看| 欧美色就是色| 久久精品一区二区三区中文字幕| 欧美韩国日本精品一区二区三区| 在线a人片免费观看视频| 精品少妇人妻av一区二区三区| а√天堂资源官网在线资源| 免费人成在线观看| 91porn在线观看| 国产日产欧美一区二区| 白浆视频在线观看| 免费观看的黄色网址| 亚洲黄色精品视频| 精品国产一级毛片| 性色av一区二区三区四区| 丰满少妇被猛烈进入高清播放| 国产精品五区| 亚洲成在线观看| 国产一区二区三区网站| 亚洲综合色丁香婷婷六月图片| 国产成人精品久久| 影院在线观看全集免费观看| 成人做爰69片免费| 亚洲成人激情在线| 日本a在线天堂| 伊人色综合一区二区三区影院视频| 国产白丝一区二区三区| gay网站在线| 亚洲高清在线不卡| 欧美一区二区麻豆红桃视频| 91中文在线视频| zzzwww在线看片免费| 精品视频123区在线观看| 91蜜桃臀久久一区二区| 欧美成人精品在线观看| 亚洲一二三在线| sm久久捆绑调教精品一区| 亚洲精品中文字幕乱码三区91| 精品一区久久久久久| 欧美在线www| 国产黄色免费大片| 精品人妻一区二区三区日产乱码卜| 国产精品网站入口| 中文字幕电影一区| 国产精品视频午夜| 91网站免费观看| 精品一区二区三区av| 日韩国产精品91| 精品久久99ma| 91九色综合久久| 在线观看亚洲色图| 在线国产中文字幕| 日韩jizzz| 一区二区日韩精品| 亚洲免费观看高清完整版在线观看熊| 成人h动漫精品一区二区| 国产精品99在线观看| 黄色影院在线观看| 国产成人亚洲综合a∨婷婷图片| 91九色在线免费视频| 国产又大又粗又硬| 黄色日本网站| 国产精品传媒毛片三区| 无码人妻aⅴ一区二区三区玉蒲团| 成人av影院在线观看| 亚洲理论电影| 免费日韩在线视频| 青青久久精品| 女同性恋一区二区| 日韩一区在线免费观看| 精品国产第一福利网站| 亚洲曰韩产成在线| 在线电影一区二区| 一区二区三区在线| 久久精彩免费视频| 欧美久久婷婷综合色| 亚洲专区免费| 岛国精品在线观看| 在线观看免费黄视频| 国产噜噜噜噜久久久久久久久| 电影eeuss影院www| 精品无码一区二区三区蜜臀| 不许穿内裤随时挨c调教h苏绵| 亚洲午夜精品一区二区| 亚洲午夜精品网| 精品国产123区| 中文字幕一区二区三区四区视频| 国产成人精品白浆久久69| 久久久久一区二区三区四区| 国产日韩在线一区二区三区| 国产亚洲日本欧美韩国| 欧美日本一区二区视频在线观看| 亚洲资源网你懂的| 99re6在线观看| 精品亚洲乱码一区二区| 久久视频这里有精品| 午夜福利一区二区三区| 亚洲美免无码中文字幕在线| 亚洲欧洲日夜超级视频| 亚洲激情在线视频| 亚洲国产视频直播| 日日摸夜夜添一区| 日本妇女毛茸茸| 日韩一区二区在线看片| 亚洲欧美综合久久久| 国产高清美女一级毛片久久| 78国产伦精品一区二区三区| 黄色精品视频网站| 男女小视频在线观看| 九色porny在线| 波多野结衣一区二区三区免费视频| 麻豆视频在线免费看| 欧美日韩视频| 久久久久久国产精品无码| 中文在线免费| 99精品一区二区三区无码吞精| 秋霞一区二区| 亚洲国产婷婷| xxxx69·hdxxxxx| 国产女主播在线观看| 97久久夜色精品国产九色| 狠狠色伊人亚洲综合网站色| 欧美日韩一区二区三区四区| 午夜dj在线观看高清视频完整版| 精品美女久久久久| 玩弄japan白嫩少妇hd| 国产男男chinese网站| av在线你懂的| 91免费视频黄| 日韩大陆欧美高清视频区| 日本怡春院一区二区| 无码精品a∨在线观看中文| 91麻豆精品国产综合久久久久久| 在线观看日韩毛片| 欧美亚洲综合在线| 99久久久精品免费观看国产蜜| 四虎国产成人免费观看| 91tv亚洲精品香蕉国产一区| 成全视频在线播放大地| 日韩一级视频免费观看在线| 国产97人人超碰caoprom| 欧美怡红院视频| 国产在线视频精品一区| 91麻豆精品国产自产在线| 久久亚洲精品中文字幕| 特一级黄色大片| 久久精品亚洲天堂| 色呦呦久久久| 女生裸体视频网站免费观看| 成人在线免费看片| 精品国产一区二区三区无码| 欧美午夜不卡在线观看免费| 精品一区二区三区av| 日韩小视频在线| 久草免费资源站| 亚洲免费视频播放| 中文字幕乱码无码人妻系列蜜桃| 国产精品系列视频| 久做在线视频免费观看| 亚洲男女视频在线观看| 日本熟女一区二区| 精品国产sm最大网站免费看| 九一国产在线观看| 成人久久18免费网站图片| 欧美成人sm免费视频| 色88888久久久久久影院野外| 久久成人一区二区| 亚洲国产视频二区| 日韩精品一区二区亚洲av观看| 成人性生交大片免费看96| 东北一级毛片| 在线亚洲不卡| 日韩国产在线不卡视频| 日韩成人手机在线| 男人天堂中文字幕| 欧美 丝袜 自拍 制服 另类| 伊人色综合久久天天| 国产精品不卡一区| 国产福利一区二区三区视频在线| 中文字幕观看视频| 久久久午夜精品| 国产精品久久久久久久久| 色视频网站在线观看| 福利91精品一区二区三区| 亚洲欧美高清| 欧美激情一区二区三区在线视频观看| 97超碰在线人人| 在线观看中文字幕的网站| 一卡二卡在线视频| 日韩中文字幕一区二区高清99| 欧美一区二区中文字幕| 欧美成人有码| 色欧美日韩亚洲| 国产欧美一区二区三区久久人妖| 一本久道中文无码字幕av| 天天干,天天干| 国产高潮国产高潮久久久91| 久久97超碰国产精品超碰| 亚洲wwwwww| 久久嫩草精品久久久精品一| 秋霞毛片久久久久久久久| 久久精品色欧美aⅴ一区二区| 成年人免费网站在线观看| 色综合久久久久综合| 欧美三级韩国三级日本三斤在线观看| 老司机成人影院| 成人免费视频播放| 三级电影一区| 欧美三级日韩在线| 成人在线国产精品| 日韩一区二区电影网| av观看久久| 精品入口麻豆传煤| 色网站免费在线观看| 国产电影一区二区在线观看| 欧美一区二区三区红桃小说| 一区二区毛片| 成年人免费av| 国产精品v片在线观看不卡| 黄色www视频| 国产成+人+综合+亚洲欧美丁香花| 九色视频成人自拍| 美女被内谢流白浆高视频| 欧美资源一区| 欧美国产丝袜视频| 久久久久久亚洲综合| 一区二区三区在线观看www| 日本三级中文字幕| 亚洲xxxxx性| av电影在线不卡| 日韩精品在线观看网站| 国产亚洲福利社区| 男人午夜免费视频| 在线三级av| 97色在线观看免费视频| 天天做天天摸天天爽天天爱| 午夜视频在线观| 成人国产电影在线观看| 亚洲综合自拍偷拍| 国产一区二区三区朝在线观看| 久久av一区二区三区| 免费电影网站在线观看| l8videosex性欧美69| 在线观看国产精品入口| 在线成人直播| 在线观看91久久久久久| 日韩精品中文在线观看|