-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathqsort.py
More file actions
40 lines (34 loc) · 1 KB
/
qsort.py
File metadata and controls
40 lines (34 loc) · 1 KB
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
import sys
import random
lenth = 10
def partition(arr, left, right):
"""get pivot index"""
pivot_index, pivot = left, arr[left]
arr[left], arr[right] = arr[right], arr[left]
for i in range(left, right+1):
if arr[i] < pivot:
arr[i], arr[pivot_index] = arr[pivot_index], arr[i]
pivot_index = pivot_index+1
arr[pivot_index], arr[right] = arr[right], arr[pivot_index]
return pivot_index
def qsort(arr, left, right):
"""qsort of in-place version"""
if left >= right:
return
pivot_index = partition(arr, left, right)
qsort(arr, left, pivot_index-1)
qsort(arr, pivot_index+1, right)
# print arr
def init():
"""init array"""
arr = []
sys.setrecursionlimit(100000)
for i in range(lenth):
arr.append(random.randint(0,1000))
return arr
if __name__ == '__main__':
"""TODO: it can be more pythonic """
arr = init()
print 'before qsort: ', arr
qsort(arr, 0, len(arr)-1)
print 'after qsort: ', arr