現(xiàn)在開(kāi)始介紹排序算法。為簡(jiǎn)便起見(jiàn),這里只對(duì)不重復(fù)值進(jìn)行排序(雖然部分算法可以對(duì)重復(fù)值進(jìn)行排序)。
第一個(gè)排序算法:桶排序法 桶排序法很簡(jiǎn)單,已知一個(gè)含有N個(gè)元素,最大值為M(M≥N)的數(shù)組,那么現(xiàn)在可以假定有M個(gè)編好順序的桶,將數(shù)組每個(gè)元素的值放進(jìn)該值對(duì)應(yīng)的編號(hào)的桶里,即:值為1的元素放進(jìn)1號(hào)桶, 值為2的元素放進(jìn)2號(hào)桶……如此類(lèi)推。再把空桶拿走,剩下的就是排好序的數(shù)組了。 - 已知數(shù)組arr1(),初始化下標(biāo)變量j=0。
- 準(zhǔn)備作為桶的數(shù)組arr2(),元素空間不得小于arr1()的最大值。初始化下標(biāo)i為0。
- 當(dāng)變量i<桶的個(gè)數(shù)時(shí),執(zhí)行步驟4~6。
- 將arr1(j)的值賦給桶arr2(i)
- j加1。
- i加1。
- 從第一個(gè)桶開(kāi)始,如果值非空就取出來(lái)。
在取值時(shí)我就不再使用數(shù)組了,而使用一個(gè)字符串將這些值串起來(lái)。詳見(jiàn):
- Sub bucket()
- Dim arr1(), arr2()
- Dim i As Long
- Dim j As Long
- Dim k As Long
- Dim s As String
- arr1 = Array(8, 2, 1, 5, 9, 7)
- '根據(jù)最大值為9,這里定義含有10個(gè)元素空間的數(shù)組!獢(shù)組求最大值,請(qǐng)參考前面的帖子
- ReDim arr2(0 To 9)
- For i = 0 To 9
- For j = 0 To UBound(arr1)
- If i = arr1(j) Then
- arr2(i) = arr1(j)
- End If
- Next
- If Not IsEmpty(arr2(i)) Then
- s = s & "," & arr2(i)
- End If
- Next
- Debug.Print Right(s, Len(s) - 1)
- End Sub
復(fù)制代碼基礎(chǔ)算法 【新手入門(mén)】之一:If分支語(yǔ)句
【新手入門(mén)】之二:分支語(yǔ)句總結(jié)
【新手入門(mén)】之三:循環(huán)語(yǔ)句For
【新手入門(mén)】之四:循環(huán)語(yǔ)句Do和死循環(huán)
【新手入門(mén)】之五:公共變量與傳址過(guò)程、傳值過(guò)程
【新手入門(mén)】之六:“悲歡離合總無(wú)情”——淺談Split和Join
【新手入門(mén)】之七:嵌套與并列——再談If流程問(wèn)題
【新手入門(mén)】之八:“連就連”——淺談“&”和“+”連接符的區(qū)別
【新手入門(mén)】之九:從百錢(qián)百雞談起——淺談“規(guī)劃求解”兼答lingjiang問(wèn)
【新手入門(mén)】之十:書(shū)到用時(shí)方恨少——自定義菜單(Access 2003)的制作
【新手入門(mén)】之十一:淺談ADO之序言
【新手入門(mén)】之十二:淺談ADO之Connection
【新手入門(mén)】之十三:淺談ADO之Conmmand(上)
【新手入門(mén)】之十四:淺談ADO之Command(下)
【新手入門(mén)】之十五:淺談ADO之Recordset(上)
【新手入門(mén)】之十六:淺談ADO之Recordset(下)
【新手入門(mén)】之十七:淺談列表框的使用
【新手入門(mén)】之十八:雙擊列表框修改數(shù)據(jù)
【新手入門(mén)】之十九:從“書(shū)與女友恕不外借”談起——淺談“Bookmark”的使用
【新手入門(mén)】之二十:“書(shū)與書(shū)簽”——bookmark屬性答疑
【新手入門(mén)】之二十一:記錄集的“凌遲”——逐條導(dǎo)出記錄集
【新手進(jìn)階】之一:基礎(chǔ)算法(一)
【新手進(jìn)階】之二:基礎(chǔ)算法(二)
【新手進(jìn)階】之三:基礎(chǔ)算法(三)
【新手進(jìn)階】之四:基礎(chǔ)算法(四)
【新手進(jìn)階】之五:排序搜索(一)
【新手進(jìn)階】之六:排序搜索(二)
【新手進(jìn)階】之七:遞歸算法
【新手進(jìn)階】之八:冒泡排序
【新手進(jìn)階】之九:淺談不綁定數(shù)據(jù)源操作記錄
【新手進(jìn)階】之十:工作日的計(jì)算
【新手進(jìn)階】之十一:“庖丁解!焙汀凹o(jì)昌學(xué)射”——淺談表格式文本數(shù)據(jù)的導(dǎo)入
【新手進(jìn)階】之十二:從四腳騰空的奔馬談起——原來(lái)界面可以這樣設(shè)計(jì)
【新手進(jìn)階】之十三:Outlook風(fēng)格導(dǎo)航界面
【新手進(jìn)階】之十四:倉(cāng)庫(kù)管理系統(tǒng) |