-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathquicksort2
42 lines (39 loc) · 1.08 KB
/
quicksort2
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
import random
import copy
def GenerateRandomList(number, size):
temp = []
random_legth = random.randint(0, size)
current_length = 0
while current_length < random_legth:
temp.append(random.randint(1, number))
current_length += 1
return temp
def QuickSort(arr, L, R):
if L < R:
# choose a random element as the anchor
random_index = random.randint(L, R)
p = Partition(arr, L, R, arr[random_index])
QuickSort(arr, L, p[0])
QuickSort(arr, p[1], R)
def Partition(arr, L, R, anchor):
less = L - 1
more = R + 1
cur = L
while cur < more:
if arr[cur] < anchor:
less += 1
arr[cur], arr[less] = arr[less], arr[cur]
cur += 1
elif arr[cur] == anchor:
cur += 1
else:
more -= 1
arr[cur], arr[more] = arr[more], arr[cur]
return (less, more)
for i in range(100):
l = GenerateRandomList(200,100)
ls= sorted(l)
QuickSort(l, 0 , len(l) - 1)
if (ls != l):
print('Wrong!')
print('Done!')