-
Notifications
You must be signed in to change notification settings - Fork 88
/
Copy pathmergesort.swift
49 lines (41 loc) · 1.29 KB
/
mergesort.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
func merge<T: Comparable>(_ leftArray: [T], _ rightArray: [T]) ->[T] {
var sortedArray: [T] = []
var rightIdx = 0
var leftIdx = 0
while leftIdx < leftArray.count && rightIdx < rightArray.count {
let left = leftArray[leftIdx]
let right = rightArray[rightIdx]
if left > right {
sortedArray.append(right)
rightIdx += 1
}
else if left < right {
sortedArray.append(left)
leftIdx += 1
}
else {
sortedArray.append(left)
leftIdx += 1
sortedArray.append(right)
rightIdx += 1
}
}
while leftIdx < leftArray.count {
sortedArray.append(leftArray[leftIdx])
leftIdx += 1
}
while rightIdx < rightArray.count {
sortedArray.append(rightArray[rightIdx])
rightIdx += 1
}
return sortedArray
}
func mergeSort<T: Comparable>(_ array: [T]) ->[T] {
if array.count <= 1 {return array}
let middleIdx = array.count/2
let leftArray = mergeSort(Array(array[0..<middleIdx]))
let rightArray = mergeSort(Array(array[middleIdx..<array.count]))
return merge(leftArray, rightArray)
}
let test_1 = [5,9,1,3,4,6,6,3,2]
print(mergeSort(test_1))