swift&C雙語(yǔ)版算法之桶排序

桶排序

桶排序(Bucket Sort)的原理很簡(jiǎn)單痹仙,它是將數(shù)組分到有限數(shù)量的桶子里是尔。假設(shè)待排序的數(shù)組a中共有N個(gè)整數(shù),并且已知數(shù)組a中數(shù)據(jù)的范圍[0, MAX)蝶溶。在桶排序時(shí)嗜历,創(chuàng)建容量為MAX的桶數(shù)組r,并將桶數(shù)組元素都初始化為0抖所;將容量為MAX的桶數(shù)組中的每一個(gè)單元都看作一個(gè)"桶"梨州。在排序時(shí),逐個(gè)遍歷數(shù)組a田轧,將數(shù)組a的值暴匠,作為"桶數(shù)組r"的下標(biāo)。當(dāng)a中數(shù)據(jù)被讀取時(shí)傻粘,就將桶的值加1每窖。例如,讀取到數(shù)組a[3]=5弦悉,則將r[5]的值+1窒典。

swift

<pre>
func bucketSort(originArray: [Int]) -> [Int] {

let maxNum = originNum.max()
//桶的數(shù)目
var bucket:[Int] = Array.init(repeatElement(0, count: maxNum! + 1))
var newNum:[Int] = Array.init()

//給桶加標(biāo)記
for index in originNum {
    let numId = index
    bucket[numId] += 1
}

for index in bucket.indices {
    
    while bucket[index] > 0 {
        newNum.append(index)
        bucket[index] -= 1
    }
}

return newNum

}

//運(yùn)行結(jié)果
let originNum :[Int] = [2,3,45,7,17,99,25,25,14,75,48,14,2,3,7,17]
let newNum = bucketSort(originArray: originNum)
print(newNum)
//[2, 2, 3, 3, 7, 7, 14, 14, 17, 17, 25, 25, 45, 48, 75, 99]**
</pre>

C

<pre>
/**

  • 桶排序

  • @param num 待排序數(shù)組

  • @param numMax 數(shù)組的最大值

  • @param count 數(shù)組元素個(gè)數(shù)
    */
    bucket_sort(int num[],int numMax, int count)
    {
    //桶數(shù)目
    int bucketNum = numMax + 1;
    int bucket[bucketNum];
    for (int i = 0; i < bucketNum; i++) {
    bucket[i] = 0;
    }

    //給桶加標(biāo)記
    for (int i = 0; i < count; i++) {
    int numId = num[i];
    bucket[numId]++;
    }

    for (int i = 0; i < numMax; i++) {
    for (int j = 1; j <= bucket[i] ; j++) {
    printf("%d \n",i);
    }
    }

}

//運(yùn)行結(jié)果
int num[] = {2,3,45,7,17,99,25,25,14,75,48,14,2,3,7,17};
int count = sizeof(num) / sizeof(int);
bucket_sort(num,100,count);
//2,2,3,3,7,7,14,14,17,17,25,25,45,48,75,99,Program ended with exit code: 0
</pre>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市稽莉,隨后出現(xiàn)的幾起案子瀑志,更是在濱河造成了極大的恐慌,老刑警劉巖污秆,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件劈猪,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡良拼,警方通過(guò)查閱死者的電腦和手機(jī)战得,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)庸推,“玉大人常侦,你說(shuō)我怎么就攤上這事浇冰。” “怎么了聋亡?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵湖饱,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我杀捻,道長(zhǎng),這世上最難降的妖魔是什么蚓庭? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任致讥,我火速辦了婚禮,結(jié)果婚禮上器赞,老公的妹妹穿的比我還像新娘垢袱。我一直安慰自己,他們只是感情好港柜,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布请契。 她就那樣靜靜地躺著,像睡著了一般夏醉。 火紅的嫁衣襯著肌膚如雪爽锥。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,749評(píng)論 1 289
  • 那天畔柔,我揣著相機(jī)與錄音氯夷,去河邊找鬼。 笑死靶擦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播桨啃,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼不瓶,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了枚粘?” 一聲冷哼從身側(cè)響起馅闽,我...
    開(kāi)封第一講書(shū)人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎赌结,沒(méi)想到半個(gè)月后捞蛋,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡柬姚,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年拟杉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片量承。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡搬设,死狀恐怖穴店,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拿穴,我是刑警寧澤泣洞,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站默色,受9級(jí)特大地震影響球凰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜腿宰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一呕诉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧吃度,春花似錦甩挫、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至间护,卻和暖如春亦渗,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背汁尺。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工央碟, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人均函。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓亿虽,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親苞也。 傳聞我的和親對(duì)象是個(gè)殘疾皇子洛勉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 概述 排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序如迟,而外部排序是因排序的數(shù)據(jù)很大收毫,一次不能容納全部...
    蟻前閱讀 5,168評(píng)論 0 52
  • 概述:排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序殷勘,而外部排序是因排序的數(shù)據(jù)很大此再,一次不能容納全部...
    每天刷兩次牙閱讀 3,729評(píng)論 0 15
  • 數(shù)據(jù)結(jié)構(gòu)與算法——計(jì)數(shù)排序策吠、桶排序逛裤、基數(shù)排序 計(jì)數(shù)排序 計(jì)數(shù)排序有如下四個(gè)步驟。 首先會(huì)對(duì)每個(gè)輸入進(jìn)行頻率統(tǒng)計(jì)猴抹,得...
    sunhaiyu閱讀 1,102評(píng)論 0 11
  • 所有內(nèi)部排序算法的一個(gè)總結(jié)表格 簡(jiǎn)單選擇排序 首先在未排序序列中找到最小(大)元素蟀给,存放到排序序列的起始位置跋理,然后...
    fredal閱讀 3,236評(píng)論 4 132
  • 概述排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序汁政,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部的...
    Luc_閱讀 2,259評(píng)論 0 35