iOS(Object C) 插入排序

插入排序的思想:

可以想象你在打牌,手里有一张牌2,

第一次摸到一张牌5; 5 比1 大,所以摸到的牌5放在1的右边; (此时手里的牌为 2->5)

第二次摸到一张牌3; 3比5小,所以3和5互换位置,再拿3和2比,3比2大,3不动(此时手里的牌为 2-> 3 -> 5)

第三次摸到一张牌1,1比5小,所以1和5互换位置;再拿1和3比,1比3小,所以1和3互换位置;再拿1和3比,1比2小,所以1和2互换位置;

代码为:

objectivec 复制代码
- (NSMutableArray *)insertArray:(NSMutableArray *)array
{
    int j = 0;
    for (int i = 1; i < array.count; i ++)  //i表示摸到的牌的下标
    {
        j = i -1; //j 指的是手里的牌的下标
        
        while (j >= 0 && [array[j] intValue]> [array[i] intValue])
        {
            //交换j和j+1的值, 这里的j+1,其实就是array[i]的值
            [array exchangeObjectAtIndex:j+1 withObjectAtIndex:j];
            //j往后退一步,再继续与array[i]比大小
            j -= 1;
        }
        
        NSLog(@"插入排序,第 %d 轮后 array===%@",i,[array componentsJoinedByString:@" "]);
    }
    
    return array;
}

插入排序还有另一种写法,我个人觉得比较难理解:

就是比较牌的时候不交换位置,仅仅是把大的牌往后移,最后再把摸到的牌放到它该去的地方:

代码如下:

objectivec 复制代码
- (NSMutableArray *)insertArray:(NSMutableArray *)array
{
    //插入排序写法2.
    int j = 0;
    NSString * tempI; //每一次摸到的牌
    for (int i = 1; i < array.count; i ++)  //i表示摸到的牌的下标
    {
        tempI = array[i];
        j = i -1; //j 指的是手里的牌的下标
        
        while (j >= 0 && [array[j] intValue]> [tempI intValue])
        {
            array[j+1] = array[j];
            j -= 1;
        }
        array[j+1] = tempI;
        
        NSLog(@"插入排序,第 %d 轮后 array===%@",i,[array componentsJoinedByString:@" "]);
    }
    
    
    return array;
}
相关推荐
PAK向日葵3 分钟前
【算法导论】PDD 0817笔试题题解
算法·面试
地平线开发者3 小时前
ReID/OSNet 算法模型量化转换实践
算法·自动驾驶
地平线开发者3 小时前
开发者说|EmbodiedGen:为具身智能打造可交互3D世界生成引擎
算法·自动驾驶
星星火柴9364 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
艾莉丝努力练剑5 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
C++、Java和Python的菜鸟6 小时前
第六章 统计初步
算法·机器学习·概率论
Cx330❀6 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
散1126 小时前
01数据结构-Prim算法
数据结构·算法·图论
起个昵称吧7 小时前
线程相关编程、线程间通信、互斥锁
linux·算法
..过云雨7 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习