美文网首页
算法-排序

算法-排序

作者: 小DB | 来源:发表于2018-04-01 22:02 被阅读0次

文章涉及的全都是由小到大排序

简单选择排序:O(n^2)

外层进行n-1次循环,每次指定当前的第i个元素为最小值,保存下标,内层n-i+1次循环依次与当前保存的最小值下标的数进行比较,如果比所存下标内的数更小,则保存这个下表,内层循环结束,若i 与最小值下标不相等,则交换

//选择排序
- (NSMutableArray *)selectSort:(NSMutableArray *)array{
    NSInteger n = array.count;
    NSInteger min;
    for (NSInteger i = 0; i < n-1 ; i++) {
        min = i;
        for (NSInteger j = i+1; j<n; j++) {
            if ([array[min] intValue] > [array[j] intValue]) {
                min = j;
            }
        }
        if (min != i) {
            id tmp =array[i];
            array[i] = array[min];
            array[min] = tmp;
        }
    }
    return array;
}

冒泡排序:O(n^2)

从第一个位置开始,相邻两个位置的元素进行比较,如果反序,则进行交换,一次循环确定一个数的具体位置,进行n-1次循环

- (NSMutableArray *)sort:(NSMutableArray *)array{
    NSInteger n = array.count;
    //n-1次循环就可以了
    for (NSUInteger i = 0; i < n -1; i ++) {
        for (NSUInteger j = 1; j < n- i; j++) {
            if ([array[j-1] intValue] > [array[j] intValue]) {
                id tmp = array[j];
                array[j] = array[j-1];
                array[j-1] = tmp;
            }
        }
    }
    return array;
}

冒泡排序优化:再一次冒泡循环过程中更没有进行交换,说明待排序的序列已经有序了,使用一个标识位如果此次循环没有交换数据退出循环

- (NSMutableArray *)selectSort:(NSMutableArray *)array{
    NSInteger n = array.count;
    NSInteger min;
    for (NSInteger i = 0; i < n-1 ; i++) {
        min = i;
        BOOL notFinished = YES;
        for (NSInteger j = i+1; j<n; j++) {
            if ([array[min] intValue] > [array[j] intValue]) {
                min = j;
                notFinished = NO;
            }
        }
        if (min != i) {
            id tmp =array[i];
            array[i] = array[min];
            array[min] = tmp;
        }
        if (notFinished) {
            break;
        }
    }
    return array;
}

插入排序:O(n^2)

将一个记录插入到已经排好序的序表中,从第二个数开始,进行n-1次循环,如果当前这个数小于前面的数,则一次与前面列表内的数进行比较,大于这个记录的都向后移动,然后将这个数插入正确的位置。

//插入排序
- (NSMutableArray *)insertSort:(NSMutableArray *)array{
    NSInteger n = array.count;
    for (NSInteger i = 1; i < n ; i++) {
        id currentNum = array[i];
        NSInteger currentIndex = i;
        for (NSInteger j = i - 1; j >= 0; j--) {
            if ([array[j] intValue] > [currentNum intValue]) {
                array[j+1] = array[j];
                array[j] = currentNum;
                currentIndex = j;
            }
        }
    }
    return array;
}

归并排序:O(n log n)

将一个待排序序列看成是n个有序的序列,相邻的两个有序序列组合成一个有序序列,这样就有n/2个有序序列,再将相邻的两个有序序列组合成一个有序序列,这样就有n/4个有序序列,如此反复下去,最终得到一个长度为n的有序序列。

相关文章

  • java实现快速排序、归并排序、希尔排序、基数排序算法...

    快速排序算法 归并排序算法 希尔排序算法 基数排序算法

  • web开发需要知道的几个算法

    算法分类 快速排序算法 深度优先算法 广度优先算法 堆排序算法 归并排序算法

  • 算法学习(1)-排序算法

    八大排序算法九大排序算法再总结[经典排序算法][集锦][直观学习排序算法] 视觉直观感受若干常用排序算法 快速排序...

  • 经典排序算法总结

    经典排序算法集锦 冒泡法 排序算法入门之冒泡排序 排序算法入门之冒泡排序优化

  • 前端算法学习-第一篇

    冒泡排序算法 冒泡排序算法是最慢的排序算法之一,也是最容易实现的排序算法。之所以叫冒泡排序是因为使用这种算法排序时...

  • 七大排序算法之冒泡排序

    七大排序算法之冒泡排序 @(算法笔记)[排序算法, 冒泡排序, C++实现] 冒泡排序介绍 冒泡排序是七大排序算法...

  • 算法-选择排序

    算 法:选择排序算法时间复杂度: 选择排序算法概述 选择排序伪代码 选择排序实现 选择排序算法概述 排序算法有许...

  • 浅谈排序算法

    排序算法有很多种,今天先谈谈一些简单的排序算法。包括桶排序、冒泡排序和快速排序算法。后期总结各种排序算法。 桶排序...

  • 线性排序

    桶排序、计数排序、基数排序 一、线性排序算法介绍 1.线性排序算法包括桶排序、计数排序、基数排序。2.线性排序算法...

  • 算法4:插入排序和选择排序算法的比较

    排序算法列表电梯: 选择排序算法:详见 《算法4》2.1 - 选择排序算法(Selection Sort), Py...

网友评论

      本文标题:算法-排序

      本文链接:https://www.haomeiwen.com/subject/hmzacftx.html