Я бы предложил использовать пользовательскую реализацию быстрой сортировки:
// MARK: - Array<Element: Comparable>
extension Array where Element: Comparable {
// MARK: - Internal
mutating func quickSort(subrange: Range<Int>) {
privateQuickSort(left: subrange.lowerBound, right: subrange.upperBound - 1)
}
// MARK: - Private
mutating private func partition(left: Int, right: Int) -> Int {
var i = left
for j in (left + 1)..<(right + 1) {
if self[j] < self[left] {
i += 1
(self[i], self[j]) = (self[j], self[i])
}
}
(self[i], self[left]) = (self[left], self[i])
return i
}
mutating private func privateQuickSort(left: Int, right: Int) {
if right > left {
let pivotIndex = partition(left: left, right: right)
privateQuickSort(left: left, right: pivotIndex - 1)
privateQuickSort(left: pivotIndex + 1, right: right)
}
}
}
var array = [10,0,2,1,4,5,6,7,8,3]
array.quickSort(subrange: 0..<array.count)
print(array)
[0, 1, 2, 3, 4, 5, 6, 7, 8, 10]
Но для
var array = [10,0,2,1,4,5,6,7,8,3]
array.quickSort(subrange: 0..<2)
[0, 10, 2, 1, 4, 5, 6, 7, 8, 3]
Оригинальная быстрая сортировкабыстрый алгоритм источник