Swift-快速排序

快速排序作為分治代表,通常實現由三步

  1. 數據中選擇一個元素作為”基準”(pivot),通常選取最后一個元素;
  2. 分區(partition) 所有小于”基準”的元素,都移到”基準”的左邊;所有大于”基準”的元素,都移到”基準”的右邊。分區操作結束后,基準元素所處的位置就是最終排序后它的位置。
  3. 對”基準”左邊和右邊的兩個子集,不斷重復第一步和第二步,直到所有子集只剩下一個元素為止。

實現過程中有兩種算法可以參考,一種是需要額外空間,另外一種就是經典的原地排序,第一種效率比較低,比較容易看懂;

輔助空間

   func quickSort(data:[Int])->[Int]{
        if data.count<=1 {
            return data
        }
        
        var left:[Int] = []
        var right:[Int] = []
        let pivot:Int = data[data.count-1]
        for index in 0..<data.count-1 {
            if data[index] < pivot {
                left.append(data[index])
            }else{
                right.append(data[index])
            }
        }
        
        var result = quickSort(data: left)
        result.append(pivot)
        let rightResult = quickSort(data: right)
        result.append(contentsOf: rightResult)
        return result
    }

經典快排

   func partition( data:inout [Int],low:Int,high:Int) -> Int {
        
        let root = data[high]
        var index = low
        for i in low...high {
            if data[i] < root {
                if i != index {
                    swap(&data[i], &data[index])
                }
                index = index+1
            }
        }
        
        if high != index {
            swap(&data[high], &data[index])
        }
        return index
    }
    
    func quickSort(data:inout [Int],low:Int,high:Int) -> Void {
        if low > high {
            return
        }
        let sortIndex = partition(data: &data, low: low, high: high)
        quickSort(data: &data, low: low, high: sortIndex-1)
        quickSort(data: &data, low: sortIndex+1, high: high)
    }

測試代碼:

        let data:[Int] = [1,2,3,2,4,8,9,10,19,0]
        let result = quickSort(data: data)
        print("FlyElephant方案1:-\(result)")
        
        var arr:[Int] = [10,3,17,8,5,2,1,9,5,4]
        quickSort(data: &arr, low: 0, high: arr.count-1)
        print("FlyElephant方案2:-\(arr)")
FlyElephant.png
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 前言 八大排序,三大查找是《數據結構》當中非常基礎的知識點,在這里為了復習順帶總結了一下常見的八種排序算法。常見的...
    LeeLom閱讀 97,992評論 41 662
  • quicksort可以說是應用最廣泛的排序算法之一,它的基本思想是分治法,選擇一個pivot(中軸點),將小于pi...
    黎景陽閱讀 471評論 0 1
  • 簡單排序 冒泡排序:循環遍歷左右比較,較小者左移或較大者后移; 選擇排序:在未排序序列中找到最小者元素一次放到已排...
    王然Gondole閱讀 1,432評論 0 2
  • 一、直接插入排序 直接插入排序(Insertion Sort)的基本思想是:每次將一個待排序的元素記錄,按其關鍵字...
    kevin16929閱讀 579評論 0 0
  • 好像在經歷了一場狂歡后陷入了彷徨的黑暗中。心中有無數的話想站在最高樓沖著整個世界吶喊,但最終還是選擇一筆一劃寫在這...
    何處言七月閱讀 288評論 0 0