forked from HuberTRoy/leetCode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsotred.py
141 lines (103 loc) · 3.51 KB
/
sotred.py
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
# 各种排序。
import random
test_list = (
list(range(10)),
list(range(100)),
list(range(1000)),
list(range(10001)),
list(range(50000))
)
list(map(random.shuffle, test_list))
result = (
list(range(10)),
list(range(100)),
list(range(1000)),
list(range(10001)),
list(range(50000))
)
# 选择排序:
# 每次选取一个最小的值。
def selectionSort(shuffledList):
new = []
for i in range(len(shuffledList)):
currentMinValue = min(shuffledList)
new.append(currentMinValue)
shuffledList.remove(currentMinValue)
return new
# 插入排序。
# 例:
# 插入排序一次只换一格。
# 4, 2, 3, 5, 9, 6, 1
# 2, 4, 3, 5, 9, 6, 1
# def insertingSort(shuffledList):
# new = shuffledList.copy()
# length = len(new)
# for i in range(1, length):
# if new[i] < new[i-1]:
# new[i], new[i-1] = new[i-1], new[i]
# return new
# def insertingSort(lst):
# for i in range(1,len(lst)):
# j = 0
# while lst[i] > lst[j]:
# j += 1
# results = lst[i]
# lst.pop(i)
# lst.insert(j,results)
# return lst
# 归并排序
# 归并排序是将一个大问题分解成多个小问题来解决。
# 归并排序包含两个步骤,其一是分解,其二是合并。
# 在排序中分解的过程就是将一整个数组分解为多个小数组。
# 合并则是两两合并,每次都分别从一个数组中提取一个进行比较,将较小的放入新的数组中。
def combined(list1, list2):
new = []
indexOne = 0
indexTwo = 0
lengthOne, lengthTwo = len(list1), len(list2)
while indexOne < lengthOne and indexTwo < lengthTwo:
valueOne = list1[indexOne]
valueTwo = list2[indexTwo]
if valueOne > valueTwo:
new.append(valueTwo)
indexTwo += 1
else:
new.append(valueOne)
indexOne +=1
if indexOne == lengthOne:
new.extend(list2[indexTwo:])
return new
if indexTwo == lengthTwo:
new.extend(list1[indexOne:])
return new
def makeValueInList(value):
return [value]
def reduce(splitedList):
length = len(splitedList)
if length == 1:
return splitedList[0]
middle = length // 2
left = reduce(splitedList[:middle])
right = reduce(splitedList[middle:])
return combined(left, right)
def mergeSort(shuffledList):
splitedList = list(map(makeValueInList, shuffledList))
result = reduce(splitedList)
return result
# 快速排序
# 快速排序的思路与归并排序一样都是基于分治,将一个大问题变成小问题再组合起来。
# 快排的平均时间消耗是O(logn), 当然最差也有n²。
# 快排的思路是,选取一个元素,将大于它的放在左边,小于的放在右边。然后将左边右边再次进行相同的操作。
def fastSort(shuffledList):
if len(shuffledList) <= 1:
return shuffledList
right = [i for i in shuffledList[1:] if i < shuffledList[0]]
left = [i for i in shuffledList[1:] if i >= shuffledList[0]]
return fastSort(right) + [shuffledList[0]] + fastSort(left)
for i, j in zip(test_list, result):
assert fastSort(i) == j
# assert mergeSort(i) == j
# break
# assert insertingSort(i) == j
# assert selectionSort(i) == j
# assert sorted(i) == j