CSE 221/ICT221 Analysis and Design of Algorithms Lecture 05: Analysis of time Complexity of Sorting Algorithms Dr.Surasak Mungsing Oct-151
10/6/ Sorting Algorithms Bin Sort Radix Sort Insertion Sort Shell Sort Selection Sort Heap Sort Bubble Sort Quick Sort Merge Sort CSE221/ICT221 Analysis and Design of Algorithms
10/6/ CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Bin Sort A2C5B4J3H3I4D4E3F0G4 FAE H J B D G I C Bin 0Bin 1Bin 2Bin 3Bin 4Bin 5 F0E3A2C5G4I4H3J3B4D4 (a) Input chain (b) Nodes in bins (c) Sorted chain CSE221/ICT221 Analysis and Design of Algorithms
10/6/20155 Radix Sort with r=10 and d= (a) Input chain (d) Chain after sorting on most significant digit (c) Chain after sorting on second-least significant digit (b) Chain after sorting on least significant digit
10/6/20156 Insertion Sort Concept
10/6/ CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Shell Sort Algorithm CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Shell Sort Algorithm CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Shell Sort Algorithm CSE221/ICT221 Analysis and Design of Algorithms
10/6/ CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Shell Sort Demo Shell Sort Demo
10/6/ Selection Sort Concept CSE221/ICT221 Analysis and Design of Algorithms
10/6/201514
10/6/ Heap Sort Algorithm CSE221/ICT221 Analysis and Design of Algorithms
10/6/ CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Bubble Sort Concept
10/6/201518
10/6/ Quick sort Select pivot Partition The fastest known sorting algorithm in practice. CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Quick sort Quick sort small Quick sort large CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Quick sort
10/6/ Quick Sort Partitions CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Quick sort CSE221/ICT221 Analysis and Design of Algorithms
10/6/ External Sort: A simple merge CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Merge Sort CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Merge Sort CSE221/ICT221 Analysis and Design of Algorithms
10/6/ CSE221/ICT221 Analysis and Design of Algorithms
10/6/201528
10/6/ Analysis of Insertion Sort for (int i = 1; i < a.length; i++) {// insert a[i] into a[0:i-1] int t = a[i]; int j; for (j = i - 1; j >= 0 && t < a[j]; j--) a[j + 1] = a[j]; a[j + 1] = t; } CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Complexity Space/Memory Time Count a particular operation Count number of steps Asymptotic complexity CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Comparison Count for (int i = 1; i < a.length; i++) {// insert a[i] into a[0:i-1] int t = a[i]; int j; for (j = i - 1; j >= 0 && t < a[j]; j--) a[j + 1] = a[j]; a[j + 1] = t; } CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Comparison Count for (j = i - 1; j >= 0 && t < a[j]; j--) a[j + 1] = a[j]; How many comparisons are made? CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Comparison Count for (j = i - 1; j >= 0 && t < a[j]; j--) a[j + 1] = a[j]; number of compares depends on a[]s and t as well as on i CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Comparison Count Worst-case count = maximum count Best-case count = minimum count Average count CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Worst-Case Comparison Count for (j = i - 1; j >= 0 && t < a[j]; j--) a[j + 1] = a[j]; a = [1, 2, 3, 4] and t = 0 4 compares a = [1,2,3,…,i] and t = 0 i compares CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Worst-Case Comparison Count for (int i = 1; i < n; i++) for (j = i - 1; j >= 0 && t < a[j]; j--) a[j + 1] = a[j]; total compares = … + (n-1) = (n-1)n/2 = O(n 2 ) n ( i-1 ) i=2 T(n) = CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Average-Case Comparison Count for (int i = 1; i < n; i++) for (j = i - 1; j >= 0 && t < a[j]; j--) a[j + 1] = a[j]; n i=2 T = i-1 2 = O(n 2 ) CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Select pivot Partition Analysis of Quick Sort CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Main Quick Sort Routine private static void quicksort( Comparable [ ] a, int left, int right ) { /* 1*/ if( left + CUTOFF <= right ) { /* 2*/ Comparable pivot = median3( a, left, right ); // Begin partitioning /* 3*/ int i = left, j = right - 1; /* 4*/ for( ; ; ) { /* 5*/ while( a[ ++i ].compareTo( pivot ) < 0 ) { } /* 6*/ while( a[ --j ].compareTo( pivot ) > 0 ) { } /* 7*/ if( i < j ) /* 8*/ swapReferences( a, i, j ); else /* 9*/ break; } /*10*/ swapReferences( a, i, right - 1 ); // Restore pivot /*11*/ quicksort( a, left, i - 1 ); // Sort small elements /*12*/ quicksort( a, i + 1, right ); // Sort large elements } else // Do an insertion sort on the subarray /*13*/ insertionSort( a, left, right ); } CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Worst-Case Analysis เวลาที่ใช้ในการ run quick sort เท่ากับเวลาที่ใช้ในการทำ recursive call 2 ครั้ง + linear time ที่ใช้ในการเลือก pivot ซึ่งทำให้ basic quick sort relation เท่ากับ T(n) = T(i) + T(n-i-1) + cn ในกรณี Worst- case เช่น การที่ pivot มีค่าน้อยที่สุดเสมอ เวลา ที่ใช้ในการทำ recursion คือ T(n) = T(n-1) + cnn>1 T(n-1)= T(n-2)+c(n-1) T(n-2)= T(n-3)+c(n-2) … T(2) = T(1)+c(2) รวมเวลาทั้งหมด T(n) = T(1) + c n i=2 i = O(n 2 ) CSE221/ICT221 Analysis and Design of Algorithms
10/6/ The pivot is in the middle;T(n) = 2 T(n/2) + cn Divide both sides by n; Add all equations; Best-Case Analysis T(n/2) n/2 T(n) n =+ c T(2) 2 T(1) 1 = + c T(n/4) n/4 T(n/2 ) n/2 =+ c T(n/4) n/4 T(n/8) n/8 =+ c … T(n) n T(1) 1 = + c log n T(n) = c n logn + n = O(n log n) CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Average-Case Analysis (1/4) 2 N N -1 j=0 T( j ) + cN T(N) = NT(N) = N -1 j=0 T( j ) + cN 2 2 (N-1) T(N-1) = 2 + c(N – 1) 2 T( j ) N -2 j=0 Average time of T(i) and T(N-i-1 ) is 1 N N -1 j=0 T( j ) Total time;T(N) = T(i) + T(N-i-1) + c N …………..(1) Therefore …………..(2) …………..(3) …………..(4) …………..(5) CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Average-Case Analysis (2/4) …………..(6) NT(N) – (N-1) T(N-1) = 2T(N-1) +2cN - c (5) – (4); (7) divides by N(N+1); T(N) N+1 T(N-1) N 2c N+1 = + …………..(8) Rearrange terms in equation and ignore c on the right-hand side; NT(N) = (N+1) T(N-1) +2cN …………..(7) CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Average-Case Analysis (3/4) T(N) N+1 T(N-1) N 2c N+1 = + T(N-2) N-1 T(N-3) N-2 2c N-1 = + T(N-1 ) N T(N-2) N-1 2c N = + …………..(8) …………..(9) …………..(10) T(2) 3 T(1) 2 2c 3 = + …………..(11) Sun equations (8) to (11); …………..(12) N +1 i=3 T(N) N+1 T(1) 2 2c = + CSE221/ICT221 Analysis and Design of Algorithms
10/6/ Average-Case Analysis (4/4) N +1 i=3 T(N) N+1 T(1) 2 2c = + …………..(12) Sum in equation (12) ia approximately log C (N+1)+ - 3/2, which is Euler’s constant T(N) = O(Nlog N) …………..(13) and T(N) N+1 = O(log N) therefore …………..(14) In summary, time complexity of Quick sort algorithm for Average-Case is T(n) = O(n log n) CSE221/ICT221 Analysis and Design of Algorithms
6-Oct-1546