三向切分快速排序(golang實(shí)現(xiàn))

封裝成函數(shù):

//三向切分快速排序
func ThreeWayQuickSort(s []int) {
    sort3way(s, 0, len(s)-1)
}
 
//在lt之前的(lo~lt-1)都小于中間值
//在gt之前的(gt+1~hi)都大于中間值
//在lt~i-1的都等于中間值
//在i~gt的都還不確定(最終i會大于gt鞭铆,即不確定的將不復(fù)存在)
func sort3way(s []int, lo, hi int) {
    if lo >= hi {
        return
    }
    v, lt, i, gt := s[lo], lo, lo+1, hi
    for i <= gt {
        if s[i] < v {
            swap(s, i, lt)
            lt++
            i++
        } else if s[i] > v {
            swap(s, i, gt)
            gt--
        } else {
            i++
        }
    }
    sort3way(s, lo, lt-1)
    sort3way(s, gt+1, hi)
}
 
func swap(s []int, i int, j int) {
    s[i], s[j] = s[j], s[i]
}

測試:

s := []int{9, 0, 6, 5, 8, 2, 1, 7, 4, 3}
fmt.Println(s)
ThreeWayQuickSort(s)
fmt.Println(s)

輸出:
[9 0 6 5 8 2 1 7 4 3]
[0 1 2 3 4 5 6 7 8 9]

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末陪踩,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子取逾,更是在濱河造成了極大的恐慌驻粟,老刑警劉巖换吧,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件管引,死亡現(xiàn)場離奇詭異梆靖,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)在抛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進(jìn)店門钟病,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人刚梭,你說我怎么就攤上這事肠阱。” “怎么了朴读?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵屹徘,是天一觀的道長。 經(jīng)常有香客問我衅金,道長噪伊,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任氮唯,我火速辦了婚禮鉴吹,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘您觉。我一直安慰自己拙寡,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布琳水。 她就那樣靜靜地躺著,像睡著了一般般堆。 火紅的嫁衣襯著肌膚如雪在孝。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天淮摔,我揣著相機(jī)與錄音私沮,去河邊找鬼。 笑死和橙,一個胖子當(dāng)著我的面吹牛仔燕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播魔招,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼晰搀,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了办斑?” 一聲冷哼從身側(cè)響起外恕,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤杆逗,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后鳞疲,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體罪郊,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年尚洽,在試婚紗的時候發(fā)現(xiàn)自己被綠了悔橄。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡腺毫,死狀恐怖癣疟,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拴曲,我是刑警寧澤争舞,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站澈灼,受9級特大地震影響竞川,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜叁熔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一委乌、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧荣回,春花似錦遭贸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至删铃,卻和暖如春耳贬,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背猎唁。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工咒劲, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人诫隅。 一個月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓腐魂,卻偏偏與公主長得像,于是被迫代替她去往敵國和親逐纬。 傳聞我的和親對象是個殘疾皇子蛔屹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評論 2 344

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

  • 金山的WPS,相信大家都不陌生风题。WPS是十足的國產(chǎn)軟件判导,而求伯君就是開發(fā)這款軟件的巨人嫉父。在某個論壇上,有人發(fā)了這么...
    編程獅W3Cschool閱讀 2,803評論 7 3
  • 記得大學(xué)那年眼刃,早春四月的光景绕辖,我從自習(xí)室出來,陽光明媚擂红,天空湛藍(lán)仪际,天氣回暖,道路積雪雖尚未融化昵骤,但也開始顯出消融的...
    PhilipXiong閱讀 208評論 0 0
  • 在ios應(yīng)用開發(fā)過程中树碱,有時項(xiàng)目需要添加國際化。一般都是公司這邊把翻譯好的多語言execl表格給到開發(fā)人員這邊变秦。按...
    nzbypl閱讀 1,145評論 0 1
  • 我叫江小白蹦玫,生活很簡單赎婚,我的成功不簡單。 突然有一天樱溉,一個叫“江小白”的白酒品牌火了挣输。 不管是地鐵里,還是微博福贞、微...
    戴元閱讀 831評論 1 7
  • 今日份的小香課堂是要告訴大家一個好消息!D匆ā舰涌! 立秋啦!D阒伞! 雖然氣溫還沒降下來朱躺,雖然秋雨還沒下起來刁赖,雖然工資還沒漲...
    香小妹閱讀 468評論 0 0