Add build script for Swift.

This commit is contained in:
krahets
2023-02-08 20:30:05 +08:00
parent 05f0054005
commit 38751cc5f5
25 changed files with 128 additions and 1223 deletions

View File

@@ -12,8 +12,8 @@ func swap(nums: inout [Int], i: Int, j: Int) {
}
/* */
// -
func quickSortPartition(nums: inout [Int], left: Int, right: Int) -> Int {
/* */
func partition(nums: inout [Int], left: Int, right: Int) -> Int {
// nums[left]
var i = left
var j = right
@@ -30,22 +30,23 @@ func quickSortPartition(nums: inout [Int], left: Int, right: Int) -> Int {
return i //
}
// -
/* */
func quickSort(nums: inout [Int], left: Int, right: Int) {
// 1
if left >= right {
return
}
//
let pivot = quickSortPartition(nums: &nums, left: left, right: right)
let pivot = partition(nums: &nums, left: left, right: right)
//
quickSort(nums: &nums, left: left, right: pivot - 1)
quickSort(nums: &nums, left: pivot + 1, right: right)
}
/* */
// -
func quickSortMedianThree(nums: [Int], left: Int, mid: Int, right: Int) -> Int {
/* */
func medianThree(nums: [Int], left: Int, mid: Int, right: Int) -> Int {
if (nums[left] < nums[mid]) != (nums[left] < nums[right]) {
return left
} else if (nums[mid] < nums[left]) != (nums[mid] < nums[right]) {
@@ -55,42 +56,37 @@ func quickSortMedianThree(nums: [Int], left: Int, mid: Int, right: Int) -> Int {
}
}
// -
func quickSortMedianPartition(nums: inout [Int], left: Int, right: Int) -> Int {
/* */
func partitionMedian(nums: inout [Int], left: Int, right: Int) -> Int {
//
let med = quickSortMedianThree(nums: nums, left: left, mid: (left + right) / 2, right: right)
let med = medianThree(nums: nums, left: left, mid: (left + right) / 2, right: right)
//
swap(nums: &nums, i: left, j: med)
return quickSortPartition(nums: &nums, left: left, right: right)
return partition(nums: &nums, left: left, right: right)
}
// -
/* */
func quickSortMedian(nums: inout [Int], left: Int, right: Int) {
// 1
if left >= right {
return
}
//
let pivot = quickSortMedianPartition(nums: &nums, left: left, right: right)
let pivot = partitionMedian(nums: &nums, left: left, right: right)
//
quickSortMedian(nums: &nums, left: left, right: pivot - 1)
quickSortMedian(nums: &nums, left: pivot + 1, right: right)
}
/* */
// -
func quickSortTailCallPartition(nums: inout [Int], left: Int, right: Int) -> Int {
quickSortPartition(nums: &nums, left: left, right: right)
}
// -
/* */
func quickSortTailCall(nums: inout [Int], left: Int, right: Int) {
var left = left
var right = right
// 1
while left < right {
//
let pivot = quickSortTailCallPartition(nums: &nums, left: left, right: right)
let pivot = partition(nums: &nums, left: left, right: right)
//
if (pivot - left) < (right - pivot) {
quickSortTailCall(nums: &nums, left: left, right: pivot - 1) //