算法(二)--排序

1. 選擇排序:
--析:將第 i 小的元素放到 a[i] 之中。數(shù)組的第 i 個(gè)位置的左邊是 i 個(gè)最小的元素且它們不會(huì)再被訪問。
--首先,找到數(shù)組中最小的那個(gè)元素,其次,將它和數(shù)組的第一個(gè)元素交換位置(如果第一個(gè)元素就是最小元素那么它就和自己交換)。再次,在剩下的元素中找到最小的元素,將它與數(shù)組的第二個(gè)元素交換位置。如此往復(fù),直到將整個(gè)數(shù)組排序。這種方法叫做選擇排序,因?yàn)樗诓粩嗟剡x擇剩余元素之中的最小者。
--命題 A: 對(duì)于長(zhǎng)度為 N 的數(shù)組,選擇排序需要大約 N2/2 次比較和 N 次交換。
- (void)viewDidLoad {
    [super viewDidLoad];
    NSArray *array = @[@3, @8, @2, @9, @6, @10, @18, @12];
    NSArray *selCompArray = [self selectionComparable:array];
    NSLog(@"selCompArray=============%@", selCompArray);
}
- (NSArray *)selectionComparable:(NSArray *)array {
    NSMutableArray *arrayM = [NSMutableArray array];
    for (NSNumber *num in array) {
        [arrayM addObject:num];
    }
    NSInteger N = arrayM.count;
    for (NSInteger i = 0; i<N; i++) {
        // 將a[i]和a[i+1..N]中最小的元素交換
        NSInteger min = i;  // 最小元素的索引
        for (NSInteger j = i+1; j<N; j++) {
            if (arrayM[j] < arrayM[i]) {
                min = j;
                [arrayM exchangeObjectAtIndex:i withObjectAtIndex:j];
            }
        }
    }
    NSArray *comparableArray = arrayM.copy;
    return comparableArray;
}
2. 插入排序
- (void)viewDidLoad {
    [super viewDidLoad];
    NSArray *array = @[@3, @8, @2, @9, @6, @10, @18, @12];
    NSArray *insertCompArray = [self InsertionComparable:array];
    NSLog(@"insertCompArray=============%@", insertCompArray);
}
- (NSArray *)InsertionComparable:(NSArray *)array {
    NSMutableArray *arrayM = [NSMutableArray array];
    for (NSNumber *num in array) {
        [arrayM addObject:num];
    }
    NSInteger N = arrayM.count;
    // 將array按升序排列
    for (NSInteger i = 1; i<N; i++) {
        // 將 a[i] 插入到 a[i-1]、a[i-2]、a[i-3]...之中
        for (NSInteger j = i; j>0 && arrayM[j] < arrayM[j-1]; j--) {
            [arrayM exchangeObjectAtIndex:j withObjectAtIndex:j-1];
        }
    }
    NSArray *comparableArray = arrayM.copy;
    return comparableArray;
}
3. 希爾排序
- (void)viewDidLoad {
    [super viewDidLoad];
    NSArray *array = @[@3, @8, @2, @9, @6, @10, @18, @12];
    NSArray *xiErCompArray = [self xiErComparable:array];
    NSLog(@"xiErCompArray=============%@", xiErCompArray);
}
- (NSArray *)xiErComparable:(NSArray *)array {
    NSMutableArray *arrayM = [NSMutableArray array];
    for (NSNumber *num in array) {
        [arrayM addObject:num];
    }
    NSInteger N = arrayM.count;
    NSInteger h = 1;
    while (h < N/3) {
        h = 3*h +1; // 1, 4, 13, 40, 121, 364, 1093, ...
        while (h >=1) {
            for (NSInteger i = h; i<N; i++) {
                for (NSInteger j = i; j >= h && array[j] < array[j-h]; j -= h) {
                    [arrayM exchangeObjectAtIndex:j withObjectAtIndex:j-h];
                }
            }
            h = h/3;
        }
    }
    NSArray *comparableArray = arrayM.copy;
    return comparableArray;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 概述 排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部...
    蟻前閱讀 5,308評(píng)論 0 52
  • 概述:排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部...
    每天刷兩次牙閱讀 3,829評(píng)論 0 15
  • 概述排序有內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部的...
    Luc_閱讀 2,379評(píng)論 0 35
  • 一、 單項(xiàng)選擇題(共71題) 對(duì)n個(gè)元素的序列進(jìn)行冒泡排序時(shí),最少的比較次數(shù)是( )。A. n ...
    貝影閱讀 9,437評(píng)論 0 10
  • 我是個(gè)騙子,騙別人,我是個(gè)聾子。聽不見,風(fēng)吹,看著云堆。但我有手,啊,盡管活得匍匐在地,但從不失去寫的自由。不...
    我睡覺的時(shí)候不困啊閱讀 265評(píng)論 0 0

友情鏈接更多精彩內(nèi)容