插入排序

参考链接

基本思想

每次将一个待排序的元素,插入到前面已经排好序的子序列中,直到全部元素插入完成为止。

打过扑克牌的人都应该能够秒懂!!!

插入排序又分为直接插入排序、二分插入排序、链表插入等,这里只讨论直接插入排序。

算法的实现

extension Array where Element: Comparable {
    mutating func insertSort() {
        /*
         1. 整个排序过程共进行n-1趟
         2. 每次取一个元素插入到前面排好序的数组中
         */
        for i in 1 ..< count {
            let insert = self[i]
            var j = i
            while j >= 1, insert < self[j - 1] {
                self[j] = self[j - 1]
                j -= 1
            }

            self[j] = insert
        }
    }
}

改进

将 array[j] 插入到前面a[0…j-1]的有序区间所用的方法进行改写,用数据交换代替数据后移。

  • 如果 array[j] 前一个数据 array[j-1] > array[j],就交换 array[j] 和 array[j-1],再 j--

  • 直到 array[j-1] <= array[j]。这样也可以实现将一个新数据并入到有序区间。

extension Array where Element: Comparable {
    mutating func insertSort2() {
        /// 每次取一个元素插入
        for insert in 1 ..< count {
            var current = insert
            while current > 0 {
                let prev = current - 1
                /// 如果插入元素小于前一个元素就交换2者,直到找到合适插入位置
                if self[current] < self[prev] {
                    swapAt(current, prev)
                    current -= 1
                } else {
                    break
                }
            }
        }
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 总结一下常见的排序算法。 排序分内排序和外排序。内排序:指在排序期间数据对象全部存放在内存的排序。外排序:指在排序...
    jiangliang阅读 1,441评论 0 1
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,755评论 0 15
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,248评论 0 52
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,293评论 0 2
  • 概述排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的...
    Luc_阅读 2,327评论 0 35