|
1 |
| -array = [7, 5, 9, 0, 4, 1, 6, 2, 4, 8] |
2 |
| - |
3 |
| -def quick(array, start, end): |
4 |
| - if start >= end : |
5 |
| - return |
6 |
| - p = start |
7 |
| - left = start+1 |
8 |
| - right = end |
9 |
| - while left <= right : |
10 |
| - while left <= end and array[left] <= array[p] : |
11 |
| - left += 1 |
12 |
| - while right >= start and array[right] >= array[start]: |
13 |
| - right -= 1 |
14 |
| - if left > right : |
15 |
| - array[right], array[p] = array[right], array[p] |
16 |
| - else : |
17 |
| - array[left], array[right] = array[right], array[left] |
18 |
| - |
19 |
| - quick(array, start, right-1) |
20 |
| - quick(array, right+1 , end) |
21 |
| - |
22 |
| -quick(array, 0, len(array)-1 ) |
23 |
| -print(array) |
| 1 | +array = [7, 5, 9, 0, 4, 1, 6, 2, 4, 8] |
| 2 | + |
| 3 | +def quick(array, start, end): |
| 4 | + if start >= end : |
| 5 | + return |
| 6 | + p = start |
| 7 | + left = start+1 |
| 8 | + right = end |
| 9 | + while left <= right : |
| 10 | + while left <= end and array[left] <= array[p] : |
| 11 | + left += 1 |
| 12 | + while right >= start and array[right] >= array[start]: |
| 13 | + right -= 1 |
| 14 | + if left > right : |
| 15 | + array[right], array[p] = array[right], array[p] |
| 16 | + else : |
| 17 | + array[left], array[right] = array[right], array[left] |
| 18 | + |
| 19 | + quick(array, start, right-1) |
| 20 | + quick(array, right+1 , end) |
| 21 | + |
| 22 | +quick(array, 0, len(array)-1 ) |
| 23 | +print(array) |
0 commit comments