-
Notifications
You must be signed in to change notification settings - Fork 127
/
Copy pathmerge-sort.swift
54 lines (41 loc) · 1.25 KB
/
merge-sort.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
50
51
52
53
54
func merge<T: Comparable>(_ left: [T], _ right: [T]) -> [T] {
var leftIndex = 0
var rightIndex = 0
var orderedArray: [T] = []
while leftIndex < left.count && rightIndex < right.count {
let leftElement = left[leftIndex]
let rightElement = right[rightIndex]
if leftElement < rightElement {
orderedArray.append(leftElement)
leftIndex += 1
} else if leftElement > rightElement {
orderedArray.append(rightElement)
rightIndex += 1
} else {
orderedArray.append(leftElement)
leftIndex += 1
orderedArray.append(rightElement)
rightIndex += 1
}
}
while leftIndex < left.count {
orderedArray.append(left[leftIndex])
leftIndex += 1
}
while rightIndex < right.count {
orderedArray.append(right[rightIndex])
rightIndex += 1
}
return orderedArray
}
func mergeSort<T: Comparable>(_ list: [T]) -> [T] {
guard list.count > 1 else { return list }
let middleIndex = list.count / 2
let leftList = mergeSort(Array(list[0..<middleIndex]))
let rightList = mergeSort(Array(list[middleIndex..<list.count]))
return merge(leftList, rightList)
}
let list1 = ["f", "e", "d", "b", "a", "c"]
print(mergeSort(list1))
let list2 = [5, 2, 1, 6, 4, 3]
print(mergeSort(list2))