iOS算法總結(jié)-快速排序

快速排序

快速排序(Quick Sort) 的基本思想是:通過(guò)一趟排序?qū)⒋判虻挠涗浄指畛瑟?dú)立的兩部分协饲,其中一部分記錄的關(guān)鍵字均比另一部分記錄的關(guān)鍵字小,則可分別對(duì)這兩部分記錄繼續(xù)進(jìn)行排序做鹰,以達(dá)到整個(gè)序列有序的目的。

動(dòng)效圖如下:

快速排序動(dòng)效圖

排序思路:

數(shù)組選第一個(gè)數(shù),把比數(shù)小的放到數(shù)的左邊并扇,比數(shù)大的放到右邊,結(jié)束后對(duì)左右兩邊的數(shù)組作重復(fù)處理即可抡诞。

排序演示:

假設(shè)數(shù)組為 [3穷蛹,6,1昼汗,4肴熏,7,2顷窒,5]

下標(biāo) 0 1 2 3 4 5 6
排序 3 6 1 4 7 2 5

以第一個(gè)元素3為基數(shù)蛙吏,從最后一個(gè)元素開(kāi)始查找比3小的數(shù)字,發(fā)現(xiàn)2蹋肮,交換位置:

下標(biāo) 0 1 2 3 4 5 6
排序 2 6 1 4 7 3 5

從2的右面開(kāi)始與基數(shù)3比找比3大的數(shù)字出刷,找到6,交換位置:

下標(biāo) 0 1 2 3 4 5 6
排序 2 3 1 4 7 6 5

從6的左邊面開(kāi)始與基數(shù)3比坯辩,找比3小的數(shù)字馁龟,找到1,交換位置:

下標(biāo) 0 1 2 3 4 5 6
排序 2 1 3 4 7 6 5

結(jié)束第一次排序漆魔,分別開(kāi)始對(duì)3的左右兩邊的數(shù)據(jù)作循環(huán)對(duì)比坷檩,左邊:2與1對(duì)比更改位置:

下標(biāo) 0 1 2 3 4 5 6
排序 1 2 3 4 7 6 5

左邊結(jié)束。右邊:4為基數(shù)改抡,從右邊開(kāi)始找比4小的數(shù)矢炼,找不到,循環(huán)結(jié)束阿纤,因?yàn)?的左邊已經(jīng)完畢句灌,從4的右邊開(kāi)始,也就是從7開(kāi)始作基數(shù)對(duì)比,找比7小得數(shù)放到7的左面胰锌,找到5骗绕,交換位置:

下標(biāo) 0 1 2 3 4 5 6
排序 1 2 3 4 5 6 7

從5的右邊查找發(fā)現(xiàn)已經(jīng)有序,循環(huán)結(jié)束资昧。

快速排序代碼:

- (void)quickSortArray:(NSMutableArray *)array withLeftIndex:(NSInteger)leftIndex andRightIndex:(NSInteger)rightIndex
{
    if (leftIndex >= rightIndex) {//如果數(shù)組長(zhǎng)度為0或1時(shí)返回
        return ;
    }
    
    NSInteger i = leftIndex;
    NSInteger j = rightIndex;
    //記錄比較基準(zhǔn)數(shù)
    NSInteger key = [array[i] integerValue];
    
    while (i < j) {
        /**** 首先從右邊j開(kāi)始查找比基準(zhǔn)數(shù)小的值 ***/
        while (i < j && [array[j] integerValue] >= key) {//如果比基準(zhǔn)數(shù)大酬土,繼續(xù)查找
            j--;
        }
        //如果比基準(zhǔn)數(shù)小,則將查找到的小值調(diào)換到i的位置
        array[i] = array[j];
        
        /**** 當(dāng)在右邊查找到一個(gè)比基準(zhǔn)數(shù)小的值時(shí)格带,就從i開(kāi)始往后找比基準(zhǔn)數(shù)大的值 ***/
        while (i < j && [array[i] integerValue] <= key) {//如果比基準(zhǔn)數(shù)小撤缴,繼續(xù)查找
            i++;
        }
        //如果比基準(zhǔn)數(shù)大,則將查找到的大值調(diào)換到j(luò)的位置
        array[j] = array[i];
        
    }
    
    //將基準(zhǔn)數(shù)放到正確位置
    array[i] = @(key);
    
    /**** 遞歸排序 ***/
    //排序基準(zhǔn)數(shù)左邊的
    [self quickSortArray:array withLeftIndex:leftIndex andRightIndex:i - 1];
    //排序基準(zhǔn)數(shù)右邊的
    [self quickSortArray:array withLeftIndex:i + 1 andRightIndex:rightIndex];
}

    NSMutableArray * arr = @[@16,@1,@2,@9,@7,@12,@5,@3,@8,@13,@10].mutableCopy;
    [self quickSortArray:arr withLeftIndex:0 andRightIndex:arr.count-1];

打印結(jié)果為:

1, 2, 3, 5, 7, 8, 9, 10, 12, 13, 16

快速排序復(fù)雜度分析:

最優(yōu)的情況下叽唱,時(shí)間復(fù)雜度為O(nlogn),最壞的情況下為O(n2)屈呕。平實(shí)的情況為O(nlogn)

對(duì)于空間復(fù)雜度來(lái)說(shuō)棺亭,主要是遞歸造成的椓垢ぃ空間的使用,最好情況侦铜,遞歸樹(shù)的深度為log?n,其空間復(fù)雜度也就是O(logn),最壞情況专甩,需要進(jìn)行n-1次遞歸調(diào)用,空間復(fù)雜度為O(n), 平均情況钉稍,空間復(fù)雜度為O(logn)

可惜的是涤躲,由于關(guān)鍵字的比較和交換是跳躍進(jìn)行的,因此贡未,快速排序是一種不穩(wěn)定的排序方法种樱。

上一篇:iOS算法總結(jié)-歸并排序
下一篇:iOS算法總結(jié)-回顧

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市俊卤,隨后出現(xiàn)的幾起案子嫩挤,更是在濱河造成了極大的恐慌,老刑警劉巖消恍,帶你破解...
    沈念sama閱讀 212,294評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件岂昭,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡狠怨,警方通過(guò)查閱死者的電腦和手機(jī)约啊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,493評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)佣赖,“玉大人恰矩,你說(shuō)我怎么就攤上這事≡鞲颍” “怎么了外傅?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,790評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我萎胰,道長(zhǎng)彬碱,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,595評(píng)論 1 284
  • 正文 為了忘掉前任奥洼,我火速辦了婚禮,結(jié)果婚禮上晚胡,老公的妹妹穿的比我還像新娘灵奖。我一直安慰自己,他們只是感情好估盘,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,718評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布瓷患。 她就那樣靜靜地躺著,像睡著了一般遣妥。 火紅的嫁衣襯著肌膚如雪擅编。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,906評(píng)論 1 290
  • 那天箫踩,我揣著相機(jī)與錄音爱态,去河邊找鬼。 笑死境钟,一個(gè)胖子當(dāng)著我的面吹牛锦担,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播慨削,決...
    沈念sama閱讀 39,053評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼洞渔,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了缚态?” 一聲冷哼從身側(cè)響起磁椒,我...
    開(kāi)封第一講書(shū)人閱讀 37,797評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎玫芦,沒(méi)想到半個(gè)月后浆熔,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,250評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡桥帆,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,570評(píng)論 2 327
  • 正文 我和宋清朗相戀三年蘸拔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片环葵。...
    茶點(diǎn)故事閱讀 38,711評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡调窍,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出张遭,到底是詐尸還是另有隱情邓萨,我是刑警寧澤,帶...
    沈念sama閱讀 34,388評(píng)論 4 332
  • 正文 年R本政府宣布,位于F島的核電站缔恳,受9級(jí)特大地震影響宝剖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜歉甚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,018評(píng)論 3 316
  • 文/蒙蒙 一万细、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧纸泄,春花似錦赖钞、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,796評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至衡便,卻和暖如春献起,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背镣陕。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,023評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工谴餐, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人呆抑。 一個(gè)月前我還...
    沈念sama閱讀 46,461評(píng)論 2 360
  • 正文 我出身青樓总寒,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親理肺。 傳聞我的和親對(duì)象是個(gè)殘疾皇子摄闸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,595評(píng)論 2 350

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