Bucket Sort: Sorting Integers Sorting (Part II)
Sorting (Part II)
CSE 373 Data Structures
Unit 17
Reading: Section 3.2.6 Radix sort Section 7.6 Mergesort, Section 7.7, Quicksort, Sections 7.8 Lower bound
Bucket Sort: Sorting Integers
? Example: sort 8 numbers 3,6,7,4,11,3,9,7 all between 1 to 12.
? Step 1: scan the list and put the elements in the queues
1 2 3 4 5 6 7 8 9 10 11 12
34 3
67 7
9
11
? Step 2: concatenate the queues
3 4 6 7 9 11
3
7
3,3,4,6,7,7,9,11
? Time complexity: O(n+k).
3
Bucket Sort: Sorting Integers
? The goal: sort N numbers, all between 1 to k. ? Example: sort 8 numbers 3,6,7,4,11,3,5,7. All
between 1 to 12. ? The method: Use an array of k queues. Queue j
(for 1 j k) keeps the input numbers whose value is j. ? Each queue is denoted `a bucket'. ? Scan the list and put the elements in the buckets. ? Output the content of the buckets from 1 to k.
2
Radix Sort: Sorting integers
? Historically goes back to the 1890 census. ? Radix sort = multi-pass bucket sort of integers
in the range 0 to BP-1 ? Bucket-sort from least significant to most
significant "digit" (base B) ? Requires P(B+N) operations where P is the
number of passes (the number of base B digits in the largest possible input number). ? If P and B are constants then O(N) time to sort!
4
Radix Sort Example
Input data
478 537
9 721
3 38 123 67
After 1st pass
Bucket sort
by 1's digit
721
3
0123456789
123
721
3
123
537 478 9
537
67 38
67
478
38
9
This example uses B=10 and base 10 digits for simplicity of demonstration. Larger bucket counts should be used in an actual implementation.
5
Radix Sort Example
After 1st pass
721 3
123 537
67 478
38 9
Bucket sort by 10's digit
0123456789
03
721 537
09
123 38
67 478
After 2nd pass
3 9 721 123 537 38 67 478
6
Radix Sort Example
After 2nd pass
Bucket sort by 100's
3
digit
9
721
0123456789
123
003 123
478 537
721
537
009
38
038
67
067
478
After 3rd pass
3 9 38 67 123 478 537 721
Invariant: after k passes the low order k digits are sorted.
7
Properties of Radix Sort
? Not in-place
> needs lots of auxiliary storage.
? Stable
> equal keys always end up in same bucket in the same order.
? Fast
> Time to sort N numbers in the range 0 to BP-1 is O(P(B+N)) (P iterations, B buckets in each)
8
"Divide and Conquer"
? Very important strategy in computer science:
> Divide problem into smaller parts > Independently solve the parts > Combine these solutions to get overall solution
? Idea 1: Divide array into two halves, recursively sort left and right halves, then merge two halves Mergesort
? Idea 2 : Partition array into items that are "small" and items that are "large", then recursively sort the two sets Quicksort
9
Mergesort Example
82945316
Divide
Divide
82 9 4
Divide 8 2
9 4
5 3 1 6
5 3
1 6
1 element 8 2
94
53
16
Merge 2 8
4 9
3 5
1 6
Merge 2 4 8 9
1 3 5 6
Merge 1 2 3 4 5 6 8 9 11
Mergesort
82945316
? Divide it in two at the midpoint ? Conquer each side in turn (by
recursively sorting) ? Merge two halves together
10
Auxiliary Array
? The merging requires an auxiliary array.
24891356
Auxiliary array
12
Auxiliary Array
? The merging requires an auxiliary array.
24891356
1
Auxiliary array
13
Auxiliary Array
? The merging requires an auxiliary array.
24891356
12345
Auxiliary array
14
Merging
i
j
target
copy
i
j
target
normal
Left completed first
15
Merging
first
second i
j target
Right completed first
16
Merging
Merge(A[], T[] : integer array, left, right : integer) : { mid, i, j, k, l, target : integer; mid := (right + left)/2; i := left; j := mid + 1; target := left; while i < mid and j < right do if A[i] < A[j] then T[target] := A[i] ; i:= i + 1; else T[target] := A[j]; j := j + 1; target := target + 1; if i > mid then //left completed// for k := left to target-1 do A[k] := T[k]; if j > right then //right completed// k : = mid; l := right; while k > i do A[l] := A[k]; k := k-1; l := l-1; for k := left to target-1 do A[k] := T[k];
}
17
Recursive Mergesort
Mergesort(A[], T[] : integer array, left, right : integer) : { if left < right then mid := (left + right)/2; Mergesort(A,T,left,mid); Mergesort(A,T,mid+1,right); Merge(A,T,left,right);
}
MainMergesort(A[1..n]: integer array, n : integer) : { T[1..n]: integer array; Mergesort[A,T,1,n];
}
18
Iterative Mergesort
Merge by 1 Merge by 2 Merge by 4 Merge by 8
19
Iterative Mergesort
Need of a last copy
Merge by 1 Merge by 2 Merge by 4 Merge by 8 Merge by 16
20
................
................
In order to avoid copyright disputes, this page is only a partial summary.
To fulfill the demand for quickly locating and searching documents.
It is intelligent file search solution for home and business.
Related download
- sorting part i selection sort bubble sort
- cs61b lecture 6 more iteration sort an array
- lecture 7 searching and sorting algorithms
- mergesort java implementation of recursive sort
- radix sort least significant digit first
- bucket sort sorting integers sorting part ii
- mergesort and quicksort mergesort
- arrays home cs dept
- sorting and algorithm analysis harvard university
- sorting problem sorting applications