美文网首页
快速排序 Swift之Array.filter(高阶函数)实现

快速排序 Swift之Array.filter(高阶函数)实现

作者: 派大星的博客 | 来源:发表于2018-11-17 01:13 被阅读3次

原理:

快速排序使用分治法(Divide and conquer)策略来把一个序列(list)分为两个子序列(sub-lists)。

步骤:

  • 从数列中挑出一个元素,称为"基准"(pivot)

  • 重新排序数列,所有比基准值小的元素摆放在基准前面,所有比基准值大的元素摆在基准后面(相同的数可以到任一边)

  • 递归地(recursively)把小于基准值元素的子数列和大于基准值元素的子数列排序。

1、通俗解法

func quickSort(array: [Int]) -> [Int] {
    if array.count <= 1 {
        return array
    }
    let left = array.filter { (item) -> Bool in
        return item < array[0]
    }
    let middle = array.filter { (item) -> Bool in
        return item == array[0]
    }
    let right = array.filter { (item) -> Bool in
        return item > array[0]
    }
    return quickSort(array: left) + middle + quickSort(array: right)
}

var a = [5, 8, 5, 7, 41, 2, 43, 6, 601, 61, 52, 33, 6, 7, 61, 1, 3, 6, 31, 2, 30, 6]
let b = quickSort(array: a)
print(b) // [1, 2, 2, 3, 5, 5, 6, 6, 6, 6, 7, 7, 8, 30, 31, 33, 41, 43, 52, 61, 61, 601]

2、极简实现

func quickSort(_ a: [Int]) -> [Int] {
    if a.count <= 1 { return a }
    return quickSort(a.filter({$0 < a[0]})) + a.filter({$0 == a[0]}) + quickSort(a.filter({$0 > a[0]}))
}

缺点

  • 临时变量(left middle right)空间浪费
  • quickSort 内部一次循环变为三次 时间浪费
  • 排序后的数组不是原来的数组了

相关文章

  • 快速排序 Swift之Array.filter(高阶函数)实现

    原理: 快速排序使用分治法(Divide and conquer)策略来把一个序列(list)分为两个子序列(su...

  • 高阶函数,双向绑定

    高阶函数 array.filter(Boolean) 等价于 array.filter((item) => {re...

  • 11.Lambda和高阶函数(Lambda and Higher

    高阶函数 kotlin_Lambda,高阶函数 *swift_高阶函数

  • python2

    sorted()也是一个高阶函数。用sorted()排序的关键在于实现一个映射函数。 函数作为返回值 高阶函数除了...

  • Swift(二)高阶函数

    @TOC swift常用高阶函数 swift中比较常用的高阶函数有:map、flatMap、filter、redu...

  • 手写实现系列

    实现 new 方法 Object.create 的实现原理 实现数据绑定 深拷贝 防抖函数 节流函数 冒泡排序 快速排序

  • 快速排序和高阶函数

    快速排序(以下简称快排)是一种经典的排序算法,名字乍一看非常实在,细思之下却又带着点不可一世的狂傲。别的排序算法像...

  • Swift - 高阶函数map、flatMap、filter、r

    Swift 提供了如下几个高阶函数:map、flatMap、filter、reduce。使用高阶函数进行函数式编程...

  • 七大排序算法之快速排序

    七大排序算法之快速排序 @(算法笔记)[排序算法, 快速排序, C++实现] [TOC] 快速排序的介绍: 快速排...

  • 18. sorted

    sorted()函数也是一个高阶函数,它还可以接收一个key函数来实现自定义的排序,例如按绝对值大小排序:>>> ...

网友评论

      本文标题:快速排序 Swift之Array.filter(高阶函数)实现

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