欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

快速排序算法在Swift編程中的幾種代碼實現(xiàn)示例

 更新時間:2016年07月06日 10:32:37   作者:FlyElephant  
快速排序是一種不穩(wěn)定的排序,存在著優(yōu)化空間,這里我們來看快速排序算法在Swift編程中的幾種代碼實現(xiàn)示例:

總所周知 快速排序由于排序效率在同為O(N*logN)的幾種排序方法中效率較高,因此經(jīng)常被采用。
基本原理是:
數(shù)組a = [1,3,5,7,6,4,2]
1 選定一個 基準 a[0]
2 把比 a[0]小的放左邊,比a[0]大的放右邊. 中斷遞歸如果少于兩個數(shù)字 則不執(zhí)行。
3 然后再分別對兩邊 執(zhí)行 1,2,3操作。
對快速排序 的 想法
1 在待排序元素 大部分是有序的情況下, 速度 非常很快。
2 在最差的情況下,速度就很慢了。 相當于冒泡了
3 所以 快排的 優(yōu)化, 定基準 非常重要,例如待排序是有序的,基準定在中間,xiao'lv
4 時間復雜度為nlogn,不穩(wěn)定排序

輔助空間

func quickSort(data:[NSInteger])->[NSInteger]{
  if data.count<=1 {
    return data
  }

  var left:[NSInteger]=[]
  var right:[NSInteger]=[]
  let pivot:NSInteger=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(left)
  result.append(pivot)
  let rightResult=quickSort(right)
  result.appendContentsOf(rightResult)
  return result
}

經(jīng)典快排

func partition(inout data:[NSInteger],low:NSInteger,high:NSInteger) -> NSInteger {

  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(inout data:[NSInteger],low:NSInteger,high:NSInteger) -> Void {
  if low>high {
    return
  }
  let sortIndex = partition(&data, low: low, high: high)
  quickSort(&data, low: low, high: sortIndex-1)
  quickSort(&data, low: sortIndex+1, high: high)
}

測試代碼:

var data:[NSInteger] = [1,2,3,2,4,8,9,10,19,0]
var result=quickSort(data)
print("FlyElephant方案1:-\(result)")

var arr:[NSInteger] = [10,3,17,8,5,2,1,9,5,4]
quickSort(&arr, low: 0, high: arr.count-1)
print("FlyElephant方案2:-\(arr)")

201676102656922.png (351×34)

極簡版本    

 import UIKit
   extension Array {
     var decompose : (head: Element, tail: [Element])? {
       return (count > 0) ? (self[0], Array(self[1..<count])) : nil
     }
   }

   func qsortDemo(input: [Int]) -> [Int] {
     if let (pivot, rest) = input.decompose {
       let lesser = rest.filter { $0 < pivot }//這里是小于于pivot基數(shù)的分成一個數(shù)組
       let greater = rest.filter { $0 >= pivot }//這里是大于等于pivot基數(shù)的分成一個數(shù)組
       return qsortDemo(lesser) + [pivot] + qsortDemo(greater)//遞歸 拼接數(shù)組
     } else {
       return []
     }
   }

   var a:[Int] = [1,2,4,6,2,4,3,7,8]
   qsortDemo(a)

相關文章

  • Swift調用Objective-C代碼

    Swift調用Objective-C代碼

    目前Swift語言所編寫的應用才剛剛可以使用Xcode 6 GM版本提交,而Objective-C作為蘋果的主開發(fā)語言存在了很多年了。目前尚無成熟的Swift庫可用,所以當前編寫應用可以說基本離不開調用Objective-C代碼的情況。
    2014-09-09
  • Swift4.0 Array數(shù)組詳解

    Swift4.0 Array數(shù)組詳解

    這篇文章主要為大家詳細介紹了Swift4.0 Array數(shù)組的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • switch循環(huán)所支持的數(shù)據(jù)類型案例分析

    switch循環(huán)所支持的數(shù)據(jù)類型案例分析

    這篇文章主要介紹了switch循環(huán)所支持的數(shù)據(jù)類型,本文通過實際案例講解的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • swift閉包和OC block類型的使用

    swift閉包和OC block類型的使用

    這篇文章主要介紹了swift閉包和OC block類型的使用,需要的朋友可以參考下
    2017-08-08
  • swift實現(xiàn)自動輪播圖效果(UIScrollView+UIPageControl+Timer)

    swift實現(xiàn)自動輪播圖效果(UIScrollView+UIPageControl+Timer)

    這篇文章主要為大家詳細介紹了swift實現(xiàn)自動輪播圖效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • Swift編程中的初始化與反初始化完全講解

    Swift編程中的初始化與反初始化完全講解

    這篇文章主要介紹了Swift編程中的初始化與反初始化完全講解,是Swift入門學習中的基礎知識,需要的朋友可以參考下
    2015-11-11
  • 用Swift編寫自動錄音器

    用Swift編寫自動錄音器

    這篇文章主要介紹了用Swift編寫自動錄音器,有需要的朋友可以借鑒下
    2015-07-07
  • Swift類型創(chuàng)建之自定義一個類型詳解

    Swift類型創(chuàng)建之自定義一個類型詳解

    這篇文章主要介紹了Swift類型創(chuàng)建之自定義一個類型詳解,本文講解了自定義原型、實現(xiàn)默認值、支持基本布爾型初始化、支持Bool類型判斷、支持兼容各們各派的類型、完善OCBool的布爾基因體系等內容,需要的朋友可以參考下
    2015-05-05
  • Swift 4.2使用self做為變量名淺析

    Swift 4.2使用self做為變量名淺析

    這篇文章主要給大家介紹了關于Swift 4.2使用self做為變量名的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-09-09
  • Swift中的可變參數(shù)函數(shù)介紹

    Swift中的可變參數(shù)函數(shù)介紹

    這篇文章主要介紹了Swift中的可變參數(shù)函數(shù)介紹,本文實現(xiàn)了和Objective-C調用方法一樣的變參數(shù)函數(shù),需要的朋友可以參考下
    2015-01-01

最新評論