iOS(Object C) 冒泡排序

有一个无序数组,用冒泡排序法将其排成有序数组

NSMutableArray * array = [[NSMutableArray alloc]initWithObjects:@"31",@"22",@"51",@"3",@"2",@"1",@"4", nil];

冒泡排序的思想:

第一次比较:

1.将index=0和index=1的值进行比较,

2.如果index=0 > index=1,则互换他俩的位置

3.如果index0 < index=1, 则数组保持不变

4.以此类推,第二次比较的两个值为 index1 和 index2

5.需要比较 array.count-1趟

以下为最简单的冒泡排序代码

复制代码
#pragma mark 冒泡排序
- (NSMutableArray *)bubbleSortWithArray:(NSMutableArray *)array
{
    for (int i = 0; i < array.count -1 ; i++)
    {
        for (int j = 0; j < array.count -1 -i; j++)
        {
            if ([array[j] intValue] > [array[j+1] intValue])
            {
                //互换位置
                [array exchangeObjectAtIndex:j withObjectAtIndex:j+1];
            }
        }
    }
    
    return array;
}

但是还可以再优化:如果一个数组排到第2趟就已经有序,则不需要再排下去(增加时间复杂度)

不需要排下去的一句就是 不需要互换位置,我们可以设定一个值来检测是否需要换位置,如果不需要再换,则可以跳出循环:

objectivec 复制代码
#pragma mark 冒泡排序
- (NSMutableArray *)bubbleSortWithArray:(NSMutableArray *)array
{
    for (int i = 0; i < array.count -1; i ++)
    {
        //默认不需要换位置
        BOOL isChange = NO;
    
        for (int j = 0; j < array.count - 1 -i; j ++)
        {
            if ([array[j] intValue] > [array[j +1 ] intValue])
            {
                //需要换位置
                isChange = YES;
                [array exchangeObjectAtIndex:j withObjectAtIndex:j+1];
            }
        }
        
        //循环完一趟,如果不需要换位置,则说明这个数组已经是有序的
        if (isChange == NO)
        {
            break;
        }
    }
    
    return array;
}
相关推荐
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧几秒前
Jsoup: 一款Java的HTML解析器
java·开发语言·前端·后端·缓存·html
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧2 分钟前
JSP, MVC, El, JSTL, MAC
java·开发语言·mvc·mac·jsp
黎雁·泠崖3 分钟前
Java 数据结构与算法:时间空间复杂度 从入门到实战全解
java·开发语言
kyle~8 分钟前
Python---webbrowser库 跨平台打开浏览器的控制接口
开发语言·python·web
wuqingshun3141599 分钟前
简述双亲委派机制以及其优点
java·开发语言·jvm
草莓熊Lotso11 分钟前
Ext 系列文件系统核心:块、分区、inode 与块组结构详解
android·linux·c语言·开发语言·c++·人工智能·文件
七夜zippoe25 分钟前
微服务链路追踪实战:SkyWalking vs Zipkin 架构深度解析与性能优化指南
java·开发语言·微服务·springcloud·sleuth·zipkin
见叶之秋26 分钟前
C语言--动态内存管理
c语言·开发语言
Once_day2 小时前
C++之《程序员自我修养》读书总结(5)
c语言·c++·编译和链接·程序员自我修养
Albert Edison6 小时前
【Python】学生管理系统
开发语言·数据库·python