golang實(shí)現(xiàn)快速排序

快速排序算法的算法邏輯如下:

  1. 選取數(shù)組中的一個(gè)元素,將所有的比該元素小的元素放到該元素的左側(cè)搓译,比它大元素放到它的右側(cè)
  2. 對(duì)該元素的左側(cè)進(jìn)行快速排序
  3. 對(duì)該元素的右側(cè)進(jìn)行快速排序

對(duì)應(yīng)的代碼如下:

package main

import (
    "fmt"
    "math/rand"
    "time"
)

// quickSort 使用快速排序算法,排序整型數(shù)組
func quickSort(arr []int, a, b int) {
    if b-a <= 1 {
        return
    }

    // 使用隨機(jī)數(shù)優(yōu)化快速排序
    rand.Seed(time.Now().Unix())
    r := rand.Intn(b-a) + a

    c := b - 1
    arr[c], arr[r] = arr[r], arr[c]

    j := a
    for i := a; i < c; i++ {
        if arr[i] < arr[c] {
            arr[j], arr[i] = arr[i], arr[j]
            j++
        }
    }
    arr[j], arr[c] = arr[c], arr[j]
    
    quickSort(arr, a, c)
    quickSort(arr, c+1, b)
}

func main() {
    // 測(cè)試代碼
    arr := []int{9, 8, 7, 6, 5, 1, 2, 3, 4, 0}
    fmt.Println(arr)
    quickSort(arr, 0, len(arr))
    fmt.Println(arr)
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末涝动,一起剝皮案震驚了整個(gè)濱河市狸吞,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌盼铁,老刑警劉巖粗蔚,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異饶火,居然都是意外死亡鹏控,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)肤寝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)当辐,“玉大人,你說(shuō)我怎么就攤上這事醒陆∑俟梗” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)寺晌。 經(jīng)常有香客問(wèn)我世吨,道長(zhǎng),這世上最難降的妖魔是什么呻征? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任耘婚,我火速辦了婚禮,結(jié)果婚禮上陆赋,老公的妹妹穿的比我還像新娘沐祷。我一直安慰自己,他們只是感情好攒岛,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布赖临。 她就那樣靜靜地躺著,像睡著了一般灾锯。 火紅的嫁衣襯著肌膚如雪兢榨。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,837評(píng)論 1 290
  • 那天顺饮,我揣著相機(jī)與錄音吵聪,去河邊找鬼。 笑死兼雄,一個(gè)胖子當(dāng)著我的面吹牛吟逝,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播赦肋,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼块攒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了金砍?” 一聲冷哼從身側(cè)響起局蚀,我...
    開(kāi)封第一講書(shū)人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎恕稠,沒(méi)想到半個(gè)月后琅绅,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡鹅巍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年千扶,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片骆捧。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡澎羞,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出敛苇,到底是詐尸還是另有隱情妆绞,我是刑警寧澤,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站括饶,受9級(jí)特大地震影響株茶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜图焰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一启盛、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧技羔,春花似錦僵闯、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至超陆,卻和暖如春牺弹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背时呀。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留晶默,地道東北人谨娜。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像磺陡,于是被迫代替她去往敵國(guó)和親趴梢。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

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

  • 搞懂基本排序算法 上篇文章寫(xiě)了關(guān)于 Java 內(nèi)部類(lèi)的基本知識(shí)币他,感興趣的朋友可以去看一下:搞懂 JAVA 內(nèi)部類(lèi)坞靶;...
    醒著的碼者閱讀 1,176評(píng)論 3 4
  • 我一般是不會(huì)去主動(dòng)碰算法問(wèn)題的。上學(xué)的時(shí)候一個(gè)算法復(fù)雜度就把我搞煩了蝴悉,還想讓我去搞算法本身彰阴?我是這么安慰自己...
    最課程吳老師閱讀 747評(píng)論 0 1
  • 概述 排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序拍冠,而外部排序是因排序的數(shù)據(jù)很大尿这,一次不能容納全部...
    蟻前閱讀 5,170評(píng)論 0 52
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 將一個(gè)記錄插入到已排序好...
    依依玖玥閱讀 1,245評(píng)論 0 2
  • 兒子,離開(kāi)家鄉(xiāng)在外打拼也有幾個(gè)年頭了庆杜。其中的酸甜苦辣只有自己能夠體會(huì)射众。離開(kāi)父母的懷抱獨(dú)自翱翔也體現(xiàn)你成熟成長(zhǎng)的姿態(tài)...
    起點(diǎn)_8d82閱讀 287評(píng)論 0 5