iOS用oc寫幾個常用的排序算法(選擇排序隘弊,插入排序,快速排序)

用oc寫了幾個排序算法荒适,沒有特殊的修改长捧,比較容易理解,給大家參考一下吻贿。

/*
 ***選擇排序
*/
- (NSArray*)choose:(NSArray *)arr{
    if (arr.count < 2) {
        return nil;
    }
    if (arr.count == 2) {
        return nil;
    }
    NSMutableArray *muArr = [NSMutableArray arrayWithArray:arr];
    for (int i = 0; i < muArr.count - 1 ; i ++) {
        int temp = i + 1;
        for (int j = i + 1; j < muArr.count - 1; j ++) {
            if ([muArr[j + 1] intValue] <= [muArr[temp] intValue]) {
                temp = j + 1;
            }
        }
        if ([muArr[i] intValue] > [muArr[temp] intValue]) {
            NSString *tempStr = muArr[i];
            muArr[i] = muArr[temp];
            muArr[temp] = tempStr;
        }
    }
    return muArr;
}
/*
 ***插入排序
 */
- (NSArray*)insert:(NSArray*)arr{
    
    NSMutableArray *muArr = [NSMutableArray arrayWithArray:arr];
    
    for (int i = 0; i < arr.count; i ++) {
        for (int j = i - 1; j >= 0; j --) {
            
            if ([muArr[i] intValue] <= [muArr[j] intValue] && [muArr[i] intValue] >= [muArr[j - 1] intValue]) {
                NSString *tempStr = muArr[i];
                [muArr removeObjectAtIndex:i];
                [muArr insertObject:tempStr atIndex:j];
                break;
            }
        }
    }
    
    return muArr;
}

//快速排序
- (NSArray*)quick:(NSArray*)arr{
    if (arr.count == 1) {
        return arr;
    }
    if (arr.count == 2) {
        if ([arr[0] intValue] > [arr[1] intValue]) {
            return @[arr[1],arr[0]];
        }
        else{
            return arr;
        }
    }
    
    NSMutableArray *muArr1 = [NSMutableArray arrayWithArray:@[]];
    NSMutableArray *muArr2 = [NSMutableArray arrayWithArray:@[]];
    
    for (int i = 0; i < arr.count ; i ++) {
        if ([arr[i] intValue] <= [arr[arr.count / 2] intValue]) {
            [muArr1 addObject:arr[i]];
        }
        else {
            [muArr2 addObject:arr[i]];
        }
    }
    if (muArr1.count == arr.count) {
        [muArr2 addObject:arr[arr.count / 2]];
        [muArr1 removeObjectAtIndex:(arr.count / 2)];
    }
    else if (muArr2.count == arr.count){
        [muArr1 addObject:arr[arr.count / 2]];
        [muArr2 removeObjectAtIndex:(arr.count / 2)];
    }
    NSArray *arr1 = [self quick:muArr1];
    NSArray *arr2 = [self quick:muArr2];
    
    NSMutableArray *muarr = [NSMutableArray array];
    for (id temp in arr1) {
        [muarr addObject:temp];
    }
    for (id temp in arr2) {
        [muarr addObject:temp];
    }
    
    return muarr;
    
}

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
    NSArray *frontArr = @[@"G",@"D",@"A",@"F",@"E",@"M",@"H",@"Z"];
    NSArray *midArr = @[@"A",@"D",@"E",@"F",@"G",@"H",@"M",@"Z"];
    NSLog(@"%@",[self sortTree:frontArr and:midArr]);
}
//前序遍歷:G DAFE MHZ

//中序遍歷:ADEF G HMZ

//                    G
//            D               M
//        A       F       H       Z
//              E
//后序遍歷:AEFDHZMG

- (NSArray*)sortTree:(NSArray *)frontArr and:(NSArray*)midArr{
    if (frontArr.count != midArr.count || frontArr.count == 0) {
        return nil;
    }
    //拿到root節(jié)點串结。
    NSString *rootPoint = frontArr[0];
    //通過root節(jié)點和中序遍歷結(jié)果,切割出中序遍歷左右子樹舅列。(不含root節(jié)點)
    NSMutableArray *midLeftArr = [NSMutableArray array];
    NSMutableArray *midRightArr = [NSMutableArray array];
    int aNum = (int)[midArr indexOfObject:rootPoint];
    for (int i = 0; i < midArr.count ; i ++) {
        if (i < aNum) {
            [midLeftArr addObject:midArr[i]];
        }
        else if (i > aNum) {
            [midRightArr addObject:midArr[i]];
        }
    }
    //這里通過上面求出來左右子樹的節(jié)點數(shù)肌割,劃分出前序遍歷的左右子樹。
    NSArray *frontLeftArr = [frontArr subarrayWithRange:NSMakeRange(1, midLeftArr.count)];
    NSArray *frontRightArr = [frontArr subarrayWithRange:NSMakeRange(1 + midLeftArr.count, midRightArr.count)];
    //遞歸求值帐要,(把左右子樹分別看作單獨的二叉樹進行遞歸)
    NSArray *lArr = [self sortTree:frontLeftArr and:midLeftArr];
    NSArray *rArr = [self sortTree:frontRightArr and:midRightArr];
    //我們知道了左子樹和右子樹還有節(jié)點把敞,然后我們重新拼接一下就是我們需要的后序遍歷了。
    NSMutableArray *sortArr = [NSMutableArray array];
    for (int i = 0; i < lArr.count; i ++) {
        [sortArr addObject:lArr[i]];
    }
    for (int i = 0; i < rArr.count; i ++) {
        [sortArr addObject:rArr[i]];
    }
    //別忘了root節(jié)點跟在最后面
    [sortArr addObject:rootPoint];
    //返回結(jié)果就是了
    return sortArr;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末榨惠,一起剝皮案震驚了整個濱河市奋早,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌赠橙,老刑警劉巖耽装,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異期揪,居然都是意外死亡掉奄,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門凤薛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來姓建,“玉大人,你說我怎么就攤上這事缤苫∷偻茫” “怎么了?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵活玲,是天一觀的道長涣狗。 經(jīng)常有香客問我谍婉,道長,這世上最難降的妖魔是什么屑柔? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任屡萤,我火速辦了婚禮,結(jié)果婚禮上掸宛,老公的妹妹穿的比我還像新娘死陆。我一直安慰自己,他們只是感情好唧瘾,可當我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布措译。 她就那樣靜靜地躺著,像睡著了一般饰序。 火紅的嫁衣襯著肌膚如雪领虹。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天求豫,我揣著相機與錄音塌衰,去河邊找鬼。 笑死蝠嘉,一個胖子當著我的面吹牛最疆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蚤告,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼努酸,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了杜恰?” 一聲冷哼從身側(cè)響起获诈,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎心褐,沒想到半個月后舔涎,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡檬寂,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年终抽,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片桶至。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖匾旭,靈堂內(nèi)的尸體忽然破棺而出镣屹,到底是詐尸還是另有隱情,我是刑警寧澤价涝,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布女蜈,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏伪窖。R本人自食惡果不足惜逸寓,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望覆山。 院中可真熱鬧竹伸,春花似錦、人聲如沸簇宽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽魏割。三九已至譬嚣,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間钞它,已是汗流浹背拜银。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留遭垛,地道東北人尼桶。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像耻卡,于是被迫代替她去往敵國和親疯汁。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,658評論 2 350