Presentation is loading. Please wait.

Presentation is loading. Please wait.

CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 Design and Analysis of Algorithms.

Similar presentations


Presentation on theme: "CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 Design and Analysis of Algorithms."— Presentation transcript:

1 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 Design and Analysis of Algorithms Khawaja Mohiuddin Assistant Professor, Department of Computer Sciences Bahria University, Karachi Campus, Contact: khawaja.mohiuddin@bimcs.edu.pk Lecture # 6 – Sorting Algorithms

2 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 More Sorting Algorithms 2  Quick Sort  The quick sort algorithm works by sub-dividing an array into two pieces and then calling itself recursively to sort the pieces  The following pseudo-code shows the algorithm at a high level: Quicksort (Data : values[], Integer: start, Integer: end) Pick a dividing item from the array. Call it divider. Move items < divider to the front of the array. Move items >= divider to the end of the array. Let middle be the index between the pieces where divider is put. // Recursively sort the two halves of the array Quicksort (values, start, middle -1) Quicksort (values, middle + 1, end) End Quicksort

3 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 3  Quick Sort (contd.) 67595384036 55340367986 03345566789 More Sorting Algorithms

4 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 4  Quick Sort (contd.)  In the above example, we can pick the first value, 6 for divider  In the middle image, values less than divider have been moved to the beginning of the array, and values greater than or equal to divider have been moved to the end of the array  The divider item is shaded at index 6  Notice that one other item has value 6, and it comes after the divider in the array  The algorithm then calls itself recursively to sort the two pieces of the array before and after the divider item  The result is shown at the bottom in the above example More Sorting Algorithms

5 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 5  Quick Sort (contd.)  All the items in the original array are present at each level of the tree, so each level of the tree contains N items  If we add up the items that each call to quicksort must examine at any level of the tree, we get N items More Sorting Algorithms

6 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 6  Quick Sort (contd.)  That means the calls to quicksort on any level require N steps  The tree is logN levels tall, and each level requires N steps, so the algorithm’s total runtime is O(N logN)  Like heapsort, quicksort has O(N logN) expected performance  Quicksort can have O(N 2 ) performance in worst case, in which all the dividing item is less than in the part of the array that is dividing (The worst case also occurs if all the items in the array have the same value)  Heapsort has O(N logN) performance in all cases, so it is in some sense safer and more elegant  But in practice, quicksort is usually faster than heapsort, so it is the algorithm of choice for most programmers  It is also the algorithm that is used in most libraries  It is also parallelizable More Sorting Algorithms

7 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 7  Quick Sort (contd.)  The following pseudo-code shows the entire quicksort algorithm at a low level: //Sort the indicated part of the array Quicksort (Data: values[], Integer:start, Integer: end) If(start >= end) Then Return // If the list has no more than one element, it’s sorted Integer: divider = values [start] // Use the first item as the dividing item Integer: lo = start //Move items <divider to the front of the array and Integer: hi = end // items >= divider to the end of the array While (True) //Search the array from back to front starting at “hi” to find the last item where // value < “divider.” Move that item into the hole. The hole is now where that item was. While (values [hi] >=divider) hi = hi - 1 If (hi End While More Sorting Algorithms

8 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 8  Quick Sort (contd.) If (hi <= lo) Then //The left and right pieces have met in the middle so we are done // Put the divider here, and break out of the outer while loop. values[lo]= divider End If values[lo] = values[hi] //Move the value we found to the lower half // Search the array from front to back starting at “lo” to find the first item where value >= “divider”.Move that item into the hole. The hole is now where that item was. lo = lo + 1 While (values[lo] < divider) lo = lo + 1 If(lo >= hi) Then End While If (lo>= hi) Then lo=hi // The left and right pieces have met in the middle so we are done. values[hi] = divider // Put the divider here, and break out of the outer while loop. End If values [hi] = values[lo] // Move the value we found to the upper half. End While Quicksort (values, start, lo – 1) // Recursively sort the two halves. Quicksort (values, lo + 1, end) End Quicksort More Sorting Algorithms

9 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 9  Merge Sort  Like quicksort, mergesort uses a divide-and-conquer strategy  Instead of picking a dividing item and splitting the items into two groups holding items that are larger and smaller than the dividing item, mergesort splits the items into two equal halves of equal size  It then recursively calls itself to sort the two halves  When the recursive calls to mergesort return the algorithm merges the two sorted halves into a combined sorted list  The following pseudo-code shows the algorithm: Mergesort(Data: values[], Data:scratch[], Integer: start, Integer: end) If(start == end) Then Return // If the array contains only one item, it is already sorted. Integer: midpoint = (start + end) /2 // Break the array into left and right halves Mergesort (values, scratch, start, midpoint) // Call mergesort to sort the two halves Mergesort (values, scratch, midpoint + 1, end) Integer: left_index = start // Merge the two sorted halves More Sorting Algorithms

10 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 10  Merge Sort (contd.) Integer: right_index = midpoint + 1 Integer: scratch_index = left_index While (left_index <=midpoint) And (right_index <=end) If(values[left_index] <= values[right_index]) Then scratch[scratch_index] = values[left_index] left_index = left_index + 1 Else scratch[scratch_index] = values[right_index] right_index = right_index + 1 End If scratch_index = scratch_index + 1 End While More Sorting Algorithms

11 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 11  Merge Sort (contd.) For i = left_index To midpoint // Finish copying whichever half is not empty scratch[scratch_index] = values[i] scratch_index = scratch_index + 1 Next i For i = right_index To end scratch[scratch_index] = values[i] scratch_index = scratch_index + 1 Next i For i = start To end // Copy the values back into the original values array. values [i] = scratch[i] Next i End Mergesort More Sorting Algorithms

12 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 12  Merge Sort (contd.)  This algorithm also has O(N log N) run time  Like heapsort, mergesort’s run time also does not depend on the initial arrangement of the items, so it always has O(N log N) run time  And does not have a disastrous worst case like quicksort does  Like quicksort, mergesort is parrallelizable  Mergesort is particularly useful when all the data to be sorted won’t fit in memory at once  For example, suppose a program needs to sort 1 billion customer records, each of which occupies 1 MB. Loading all the data into memory at once would require 10 15 bytes of memory, or 1000 TB, which is much more than most computers have  The mergesort algorithm, however, doesn’t need to load that much memory all at once. The algorithm doesn’t even need to look at any of the items in the array until after its recursive calls to itself have returned.  At that point, the algorithm walks through the two sorted halves in a linear fashion and merges them. Moving through the items linearly reduces the computer’s need to page memory to and from disk. More Sorting Algorithms

13 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 13  Counting Sort  Countingsort works if the values we are sorting are integers that lie in a relatively small range  For example, if we need to sort 1 million integers with values between 0 and 1,000, coutingsort can provide amazingly fast performance  The basic idea behind countingsort is to count the number of items in the array that have each value  Then it is relatively easy to copy each value, in order, the required number of times back into the array  Then the following pseudo-code shows the countingsort algorithm: Countingsort(Integer: values[], Integer: max_value) Integer: counts [0 To max_value] // Make an array to hold the counts For i =0 To max_value // Initialize the array to hold the counts. // (This is not necessary in all programming languages.) counts [i] = 0 Next i More Sorting Algorithms

14 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 14  Counting Sort (contd.) // Count the items with each value For i = 0 To - 1 count[values[i]] = count[values[i]] + 1 // Add 1 to the count for this value Next i // Copy the values back into the array Integer: index = 0 For i=0 To max_value // Copy the value i into the array counts[i] times For j= 1 to counts[i] values[index] = i index = index + 1 Next j Next i End Countingsort More Sorting Algorithms

15 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 15  Counting Sort (contd.)  Let M be the number of items in the counts array (so M = max_value +1) and let N be the number of items in the values array, if your programming language doesn’t automatically initialize the counts array so that it contains 0s, the algorithm spends M steps initializing the array. It then takes N steps to count the values in the array  The algorithm finishes by copying the values back into the original array  Each value is copied once, so that part takes N steps. If any of the entries in the counts array is still 0, the program also spends some time skipping over that entry  In the worst-case, if all the values are the same, so that the counts array contains mostly 0s, it takes M steps to skip over the 0 entities  That makes the total runtime O(2 * N + M) = O(N+M)  If M is relatively small compared to N, this is much smaller than the O(N log N) performance given by other algorithms previously  In one test, quicksort(worst-case) took 4.29 seconds to sort 1 million items with values between 0 and 1,000, but it took countingsort only 0.03 seconds.  With Similar values, heapsort took roughtly 1.02 seconds More Sorting Algorithms

16 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 16  Bucket Sort  The bucketsort algorithm (also called bin sort) works by dividing items into buckets  It sorts the buckets either by recursively calling bucketsort or by using some other algorithm and then concatenates the buckets’ contents back into the original array  The following pseudo-code shows the algorithm at a high level: Bucketsort (Data : values[]) End Bucketsort More Sorting Algorithms

17 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 17  Bucket Sort (contd.)  For example, we have an array as shown below: 298519109196379761 19 10 9 7 0-1920-39 29 40-5960-79 63 61 80-99 85 91 97 Distribute 7 9 10 19 0-1920-39 29 40-5960-79 61 63 80-99 85 91 97 Sort 791019296163859197 Gather More Sorting Algorithms

18 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 18  Bucket Sort (contd.)  The buckets can be stacks, linked lists, queues, arrays or any other data structure that you find convenient  If the array contains N fairly evenly distributed items, distributing them into the buckets requires N steps times whatever time it takes to place an item in a bucket  By ignoring the constant time to place an item in a bucket, distributing the items take O(N) steps  If we use M buckets, sorting each bucket requires an expected F(N/M) steps, where F is the runtime function of the sorting algorithm that we use to sort the buckets  Multiplying this by the number of buckets M, the total time to sort all the buckets is O(M * F(N/M))  After the sorted buckets, gathering their values back into the array requires O(N) steps  Total runtime: O(N) + O(M * F(N/M)) + O(N) = O(N + M * F(N/M))  If M is a fixed fraction of N, N/M is a constant, so F(N/M) is also a constant and this simplifies to O(N+M)  In practice, M must be a relatively large fraction of N for the algorithm to perform well.  Unlike countingsort, bucketsort’s performance does not depend on the range of the values  Instead, it depends on the number of buckets we use More Sorting Algorithms

19 CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 19  Summary – Sorting Algorithms AlgorithmRuntimeTechniquesUsefulness InsertionsortO(N 2 )InsertionVery small arrays SelectionsortO(N 2 )SelectionVery small arrays BubblesortO(N 2 )Two-way passes, restricting bounds of interest Very small arrays, mostly sorted arrays HeapsortO(N logN)Heaps, storing complete trees in an array Large arrays with unknown distribution QuicksortO(N logN) expected, O(N 2 ) worst case Divide-and-conquer, swapping items into position, randomization to avoid worst-case behaviour Large arrays without too many duplicates, parallel sorting MergesortO(N logN)Divide-and-conquer, merging, external sorting Large arrays with unknown distribution, parallel sorting CoutingsortO(N+M)CountingLarge arrays of integers with a limited range of values BucketsortO(N + M)BucketsLarge arrays with reasonably uniform value distribution More Sorting Algorithms


Download ppt "CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014CSC-305 Design and Analysis of AlgorithmsBS(CS) -6 Fall-2014 Design and Analysis of Algorithms."

Similar presentations


Ads by Google