Java Programming: Program Design Including Data Structures1 Searching and Sorting  Learn the various search algorithms  Sequential and binary search.

Slides:



Advertisements
Similar presentations
Data Structures Using C++ 2E
Advertisements

Searching and Sorting Algorithms Based on D. S
Sorting Chapter Sorting Consider list x 1, x 2, x 3, … x n We seek to arrange the elements of the list in order –Ascending or descending Some O(n.
Chapter 19: Searching and Sorting Algorithms
Chapter 1 – Basic Concepts
the fourth iteration of this loop is shown here
Fall 2006CENG 7071 Algorithm Analysis. Fall 2006CENG 7072 Algorithmic Performance There are two aspects of algorithmic performance: Time Instructions.
Chapter 11 Sorting and Searching. Copyright © 2005 Pearson Addison-Wesley. All rights reserved Chapter Objectives Examine the linear search and.
C++ Programming: Program Design Including Data Structures, Third Edition Chapter 19: Heap Sort.
C++ Plus Data Structures
Cmpt-225 Algorithm Efficiency.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved Chapter 23 Algorithm Efficiency.
Algorithm Efficiency and Sorting
Sorting CS-212 Dick Steflik. Exchange Sorting Method : make n-1 passes across the data, on each pass compare adjacent items, swapping as necessary (n-1.
Analysis of Algorithm.
Elementary Data Structures and Algorithms
© 2006 Pearson Addison-Wesley. All rights reserved10 A-1 Chapter 10 Algorithm Efficiency and Sorting.
COMP s1 Computing 2 Complexity
Week 11 Sorting Algorithms. Sorting Sorting Algorithms A sorting algorithm is an algorithm that puts elements of a list in a certain order. We need sorting.
1 MT258 Computer Programming and Problem Solving Unit 9.
Liang, Introduction to Java Programming, Seventh Edition, (c) 2009 Pearson Education, Inc. All rights reserved Chapter 23 Algorithm Efficiency.
1 Sorting Algorithms (Basic) Search Algorithms BinaryInterpolation Big-O Notation Complexity Sorting, Searching, Recursion Intro to Algorithms Selection.
1 Recursion Algorithm Analysis Standard Algorithms Chapter 7.
1 Time Analysis Analyzing an algorithm = estimating the resources it requires. Time How long will it take to execute? Impossible to find exact value Depends.
C++ Programming: Program Design Including Data Structures, Third Edition Chapter 19: Searching and Sorting Algorithms.
Chapter 12 Recursion, Complexity, and Searching and Sorting
C++ Programming: Program Design Including Data Structures, Fourth Edition Chapter 19: Searching and Sorting Algorithms.
Applications of Arrays (Searching and Sorting) and Strings
Analysis of Algorithms
Chapter 19: Searching and Sorting Algorithms
C++ Programming: From Problem Analysis to Program Design, Second Edition Chapter 19: Searching and Sorting.
Data Structures Using C++ 2E Chapter 10 Sorting Algorithms.
Program Efficiency & Complexity Analysis. Algorithm Review An algorithm is a definite procedure for solving a problem in finite number of steps Algorithm.
CSC 211 Data Structures Lecture 13
Data Structures Using C++ 2E Chapter 9 Searching and Hashing Algorithms.
Chapter 14: Searching and Sorting
Chapter 5 Searching and Sorting. Copyright © 2004 Pearson Addison-Wesley. All rights reserved.1-2 Chapter Objectives Examine the linear search and binary.
Sorting Chapter Sorting Consider list x 1, x 2, x 3, … x n We seek to arrange the elements of the list in order –Ascending or descending Some O(n.
Data Structure Introduction.
Computer Science and Software Engineering University of Wisconsin - Platteville 8. Comparison of Algorithms Yan Shi CS/SE 2630 Lecture Notes Part of this.
Sort Algorithms.
1 C++ Plus Data Structures Nell Dale Chapter 10 Sorting and Searching Algorithms Slides by Sylvia Sorkin, Community College of Baltimore County - Essex.
Chapter 18: Searching and Sorting Algorithms. Objectives In this chapter, you will: Learn the various search algorithms Implement sequential and binary.
Java Methods Big-O Analysis of Algorithms Object-Oriented Programming
Introduction to Analysis of Algorithms CS342 S2004.
1 Introduction to Sorting Algorithms Sort: arrange values into an order Alphabetical Ascending numeric Descending numeric Two algorithms considered here.
Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved. Selection Sort Sorts an array by repeatedly finding the smallest.
Review 1 Selection Sort Selection Sort Algorithm Time Complexity Best case Average case Worst case Examples.
Data Structures Using C++1 Chapter 10 Sorting Algorithms.
Analysis of algorithms. What are we going to learn? Need to say that some algorithms are “better” than others Criteria for evaluation Structure of programs.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved Chapter 23 Algorithm Efficiency.
HEAPS. Review: what are the requirements of the abstract data type: priority queue? Quick removal of item with highest priority (highest or lowest key.
© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures for Java William H. Ford William R. Topp Chapter 4 Introduction.
Chapter 10: Class Vector and String, and Enumeration Types Java Programming: Program Design Including Data Structures Program Design Including Data Structures.
Java Programming: From Problem Analysis to Program Design, 4e Chapter 14 Searching and Sorting.
Data Structures Using Java1 Chapter 9 Sorting Algorithms.
1 Chapter 2 Algorithm Analysis Reading: Chapter 2.
1 CS 132 Spring 2008 Chapter 10 Sorting Algorithms.
WHICH SEARCH OR SORT IS BETTER?. COMPARING ALGORITHMS Time efficiency refers to how long it takes an algorithm to run Space efficiency refers to the amount.
Chapter 16: Searching, Sorting, and the vector Type.
Growth of Functions & Algorithms
Chapter 18: Searching and Sorting Algorithms
Introduction to Algorithms
Data Structures Using C++
Data Structures Using C++ 2E
Design and Analysis of Algorithms
Algorithm design and Analysis
C++ Plus Data Structures
Algorithm Analysis How can we demonstrate that one algorithm is superior to another without being misled by any of the following problems: Special cases.
Presentation transcript:

Java Programming: Program Design Including Data Structures1 Searching and Sorting  Learn the various search algorithms  Sequential and binary search algorithms  Learn about asymptotic and big-O notation  Learn the various sorting algorithms

Java Programming: Program Design Including Data Structures2 Searching and Sorting Algorithms Interface  All algorithms described are generic  Searching and sorting require comparisons of data  They should work on the type of data with appropriate methods to compare data items  All algorithms described are for array-based lists except merge sort  Class SearchSortAlgorithms will implement methods in this interface

Java Programming: Program Design Including Data Structures3 Search Algorithms  Each item in a data set has a special member that uniquely identifies the item in the data set  Called the key of the item  Keys are used in operations such as: searching, sorting, inserting, and deleting  Analysis of algorithms involves counting the number of key comparisons  The number of times the key of the search item is compared with the keys in the list

Java Programming: Program Design Including Data Structures4 Sequential Search public int seqSearch(T[] list, int length, T searchItem) { int loc; boolean found = false; for (loc = 0; loc < length; loc++) { if (list[loc].equals(searchItem)) { found = true; break; } if (found) return loc; else return -1; } //end seqSearch

Java Programming: Program Design Including Data Structures5 Sequential Search public int seqSearch(T[] list, int length, T searchItem) { int loc = 0; boolean found = false; while (loc < length && !found) { if (list[loc].equals(searchItem)) found = true; else loc++; } if (!found) loc = -1; return -1; } //end seqSearch

Java Programming: Program Design Including Data Structures6 Sequential Search Analysis  The statements in the for loop are repeated several times  For each iteration of the loop, the search item is compared with an element in the list  When analyzing a search algorithm, you count the number of key comparisons  Suppose that L is a list of length n  The number of key comparisons depends on where in the list the search item is located

Java Programming: Program Design Including Data Structures7 Sequential Search Analysis (continued)  Best case  The item is the first element of the list  You make only one key comparison  Worst case  The item is the last element of the list  You make n key comparisons  Average case-  On average, a successful sequential search searches half the list

algorith m efficien cy 8 Algorithm Efficiency  Space vs time  space efficiency - the amount of memory or storage a program requires  time efficiency - how long a program takes to execute  complexity theory – separate field of computer science  space complexity  time complexity  Correctness is paramount  clarity

algorth m efficien cy 9 Performance analysis  applies to both space and time efficiency  performance measured in terms of some value  usually the amount of data processed - N  cost function  numeric function that gives the performance of an algorithm in terms of one or more variables  approximation

Java Programming: Program Design Including Data Structures10 Binary Search  Method binarySearch public int binarySearch(T[] list, int length, T searchItem) { int first = 0; int last = length - 1; int mid = -1; boolean found = false; while (first <= last && !found) { mid = (first + last) / 2; Comparable compElem = (Comparable ) list[mid];

Java Programming: Program Design Including Data Structures11 Binary Search (continued)  Method binarySearch if (compElem.compareTo(searchItem) == 0) found = true; else if (compElem.compareTo(searchItem) > 0) last = mid - 1; else first = mid + 1; } if (found) return mid; else return -1; }//end binarySearch

Java Programming: Program Design Including Data Structures12 Binary Search (continued) Figure 18-1 Sorted list for a binary search Table 18-1 Values of first, last, and middle and the Number of Comparisons for Search Item 89

algorith m efficien cy 13  Dominance  given cost functions f and g, g dominates f if  c*g(x) >= f(x) (c is positive)  Asymptotic dominance  given cost functions f and g, g dominates f if  c*g(x) >= f(x) for all x >= x 0 (c, x 0 are positive)  or g asymptotically dominates f if g dominates f for all large values of x  an asymptotically dominant function overestimates the actual cost for all but small amounts of data => the upper bound of the running time for an algorithm

algorith m efficien cy 14 Estimating Functions Desirable estimating function has three characteristics 1. It asymptotically dominates the Actual Time function. 2. It is simple to express and understand. 3. It is as close to an estimate as possible.

algorith m efficien cy 15 A look at logarithms  Definitions log x b = a iff x ^a = b so log 2 8 = 3 means 2^3 = 8 log nnn log nn2n ,536

algorith m efficien cy 16 Example  ActualTime(vSize) = vSize 2 + 5*vSize  EstimateofActualTime(vSize) = vSize 2 1. estimate asymptotically dominates ActualTime  c * vSize 2 >= vSize 2 + 5*vSize Simpler to express 3. Closest estimate

algorith m efficien cy 17 Order of a function  Given two nonnegative functions f and g, the order of f is g if and only if g asymptotically dominates f  the order of f is g  f is of order g  f = O(g)// Big-O Notation

algorith m efficien cy 18 Big-O Notation  ActualTime(vSize) = O(EstimateofActualTime(vSize))  vSize 2 + 5*vSize = O(vSize 2 )  vSize 2 + 5*vSize is of order vSize 2  ActualTime(vSize) = O(vSize 2 )  the running time is of order vSize 2  relative speed

algorith m efficien cy 19 Time Complexity and Algorithm Analysis  Efficiency of different algorithms  Sequential search O(n)  Binary search O(log n)  Insertion sort O(n 2 )  Quick sort O(n log n)

algorith m efficien cy 20 Big-O Arithmetic rules  Let f and g be functions and k a constant 1. O(k * f) = O(f) 2. O(f*g) = O(f) * O(g) and O(f/g) = O(f)/O(g) 3. O(f) >= O(g) iff f dominates g 4. O(f+g) = Max[O(f),O(g)]

algorith m efficien cy 21 O(k * f) = O(f)  Constant multipliers do not affect the big-O measure  O(2*N) = O(N)  O(1.5*N) = O(N)  O(2371*N) = O(N)

algorith m efficien cy 22 O(f *g) = O(f) * O(g) O(f/g) = O(f)/O(g) O((17*N)*N) = O(17*N)*O(N) = O(N)*O(N) = O(N 2 )

algorith m efficien cy 23 O(f) >= O(g) iff f dominates g O(f+g) = Max[O(f),O(g)] O(N 5 + N 2 + N) = Max[O(N 5 ),O(N 2 ),O(N)] = O(N 5 )

algorith m efficien cy 24 Dominance rules Let X and Y denote variables and let a,b,n, and m denote constants  X X dominates X!  X! dominates a X  a X dominates b X if a > b  a X dominates x N if a > 1  X n dominates X m if n > m  X dominates log a xif a > 1  log a x dominates log b xif b > a > 1  log a x dominates 1if a > 1  Any term with a singe variable X neither dominates nor is dominated by a term with the single independent variable Y

Java Programming: Program Design Including Data Structures25 Asymptotic Notation: Big-O Notation (continued) Figure 18-9 Growth Rate of Various Functions

algorith m efficien cy 26 Examples  f(N) = 3*N * N * N  order: Max(O(3*N 4 ), O(17*N 3 ),O(13*N),)(175) = Max(O(N 4 ), O(N 3 ),O(N),)(175) = O(N 4 ) f(N) =O(N 4 ) 53 * empCount 2 O(empCount 2 ) 65*ordersFilled *ordersFilled O(ordersFilled 3 ) hdCnt * hdCnt * hdCnt 2 + 7O(hdCnt 6 ) *numsToSearchO(numsToSearch) *emps 2 + 3*emps + 4 * mngrs+6O(emps 2 + mngrs)

algorith m efficien cy 27 Categories of running time  O(1) - constant time, constant algorithms  execution time never varies with the amount of data  very efficient  O(N a ) - polynomial time  O(N) - linear time  O(N 2 ) - quadratic time  O(N 3 ) - cubic time  O(log a N) = O(log N) - logarithmic time  faster then O(N)  O(a N ) - exponential algorithms  slow, impractical

algorith m efficien cy 28 Control Structures and Run Time Performance  Single assignment statementO(1)  simple expressionO(1)  The sequencemaximum of O(S1) and O(S2)  if maximum of O(S1),O(S2), and elseO(cond)  for (i = 1;i <= N; i++)O(N * S1)

algorith m efficien cy 29 Repetition is the primary determinant of efficiency  Algorithm without loop or recursionO(1)  for (i = a;i <= b; i++)O(1)  for (i = a;i <= N; i++)O(N) //loop body requiring constant time  for (i = a;i <= N; i++)O(N 2 ) for (j = b;j <= N; j++) //loop body requiring constant time  for (i = a;i <= N; i++)O(N*M) //loop body requiring time O(M)

Java Programming: Program Design Including Data Structures30 Asymptotic Notation: Big-O Notation  Consider the following algorithm System.out.print(“Enter the first number: “); //Line 1 num1 = console.nextInt(); //Line 2 System.out.println(); //Line 3 System.out.print(“Enter the second number: “); //Line 4 num2 = console.nextInt(); //Line 5 System.out.println(); //Line 6 if (num1 >= num2) //Line 7 max = num1; //Line 8 else //Line 9 max = num2; //Line 10 System.out.println(“The maximum number is: “ + max); //Line 11

Java Programming: Program Design Including Data Structures31 Asymptotic Notation: Big-O Notation (continued)  In this algorithm, the number of operations executed is fixed  Now, consider the following algorithm

Java Programming: Program Design Including Data Structures32 Asymptotic Notation: Big-O Notation (continued) System.out.println(“Enter positive integers “ + “ending with -1”); //Line 1 count = 0; //Line 2 sum = 0; //Line 3 num = console.nextInt(); //Line 4 while (num != -1) //Line 5 { sum = sum + num; //Line 6 count++; //Line 7 num = console.nextInt(); //Line 8 } System.out.println(“The sum of the numbers is: “ + sum); //Line 9 if (count != 0) //Line 10 average = sum / count; //Line 11 else //Line 12 average = 0; //Line 13 System.out.println(“The average is: “ + average); //Line 14

Java Programming: Program Design Including Data Structures33 Asymptotic Notation: Big-O Notation (continued)  The previous algorithm executes 5n + 11 or 5n + 10 operations  Where n is the number of iterations performed by the loop  In these expressions, 5n becomes the dominating term  For large values of n  The terms 11 and 10 become negligible

Java Programming: Program Design Including Data Structures34 Asymptotic Notation: Big-O Notation (continued)  Suppose that an algorithm performs f(n) basic operations to accomplish a task  Where n is the size of the problem  f(n) gives you the efficiency of the algorithm  Different algorithms may have different efficiency functions  You can create a comparison table

Java Programming: Program Design Including Data Structures35 Asymptotic Notation: Big-O Notation (continued) Table 18-4 Growth Rate of Various Functions

Java Programming: Program Design Including Data Structures36 Asymptotic Notation: Big-O Notation (continued)  If an algorithm complexity function is similar to f(n), you can say that the function is of O(n 2 )  Called Big-O of n 2  f(n) = O(g(n)), if there exist positive constants c and n 0 such that: f(n) ≤ cg(n) for all n ≥ n 0

Java Programming: Program Design Including Data Structures37 Asymptotic Notation: Big-O Notation (continued) Table 18-7 Some Big-O Functions That Appear in Algorithm Analysis

Java Programming: Program Design Including Data Structures38 Asymptotic Notation: Big-O Notation (continued) Table 18-8 Number of Comparisons for a List of Length n

Java Programming: Program Design Including Data Structures39 Lower Bound on Comparison- Based Search Algorithms  Sequential and binary search algorithms search the list by comparing elements  These algorithms are called comparison-based search algorithms  Sequential search is of the order n  Binary search is of the order log 2 n  You cannot design a comparison-based search algorithm of an order less than log 2 n

algorith m efficien cy 40 Big-O Analysis  For complicated algorithms, big-O analysis may be difficult or impossible  typical case?  cannot capture small differences in algorithms  not applicable for small sets of data

Java Programming: Program Design Including Data Structures41 Sorting Algorithms  There are several sorting algorithms in the literature  You can analyze their implementations and efficiency

Java Programming: Program Design Including Data Structures42 Sorting a List: Bubble Sort  Method bubbleSort public void bubbleSort(T list[], int length) { for (int iteration = 1; iteration < length; iteration++) { for (int index = 0; index < length - iteration; index++) { Comparable compElem = (Comparable ) list[index]; if (compElem.compareTo(list[index + 1]) > 0) { T temp = list[index]; list[index] = list[index + 1]; list[index + 1] = temp; } }//end bubble sort

Java Programming: Program Design Including Data Structures43 Sorting a List: Bubble Sort (continued) Figure Elements of list during the first iteration Figure Elements of list during the second iteration

Java Programming: Program Design Including Data Structures44 Analysis: Bubble Sort  A sorting algorithm makes key comparisons and also moves the data  You look for both operations to analyze a sorting algorithm  The outer loop executes n – 1 times  For each iteration, the inner loop executes a certain number of times  There is one comparison per each iteration of the outer loop

Java Programming: Program Design Including Data Structures45  Total number of comparisons (general case)  Average number of assignments  Total number of comparisons (book’s method) Analysis: Bubble Sort (continued)

Java Programming: Program Design Including Data Structures46 Selection Sort: Array-Based Lists  Sorts a list by  Selecting the smallest element in the (unsorted portion of the list)  Moving this smallest element to the top of the list

Java Programming: Program Design Including Data Structures47 Selection Sort: Array-Based Lists (continued)  Method minLocation private int minLocation(T[] list, int first, int last) { int minIndex = first; for (int loc = first + 1; loc <= last; loc++) { Comparable compElem = (Comparable ) list[loc]; if (compElem.compareTo(list[minIndex]) < 0) minIndex = loc; } return minIndex; }//end minLocation

Java Programming: Program Design Including Data Structures48 Selection Sort: Array-Based Lists (continued)  Methods swap and selectionSort private void swap(T[] list, int first, int second) { T temp; temp = list[first]; list[first] = list[second]; list[second] = temp; }//end swap public void selectionSort(T[] list, int length) { for (int index = 0; index < length - 1; index++) { int minIndex = minLocation(list, index, length - 1); swap(list, index, minIndex); } }//end selectionSort

Java Programming: Program Design Including Data Structures49  Number of item assignments: 3(n – 1) = O(n)  Number of key comparisons:  Selection sort does not depend on the initial arrangement of the data Analysis: Selection Sort

Java Programming: Program Design Including Data Structures50 Insertion Sort: Array-Based Lists  Sorts a list by  Moving each element to its proper place in the sorted portion of the list  Tries to improve the performance of the selection sort  Reduces the number of key comparisons

Java Programming: Program Design Including Data Structures51 Insertion Sort: Array-Based Lists (continued)  Method insertionSort public void insertionSort(T[] list, int length) { for (int firstOutOfOrder = 1; firstOutOfOrder < length; firstOutOfOrder ++) { Comparable compElem = (Comparable ) list[firstOutOfOrder]; if (compElem.compareTo(list[firstOutOfOrder - 1]) < 0) { Comparable temp = (Comparable ) list[firstOutOfOrder];

Java Programming: Program Design Including Data Structures52 Insertion Sort: Array-Based Lists (continued) int location = firstOutOfOrder; do { list[location] = list[location - 1]; location--; } while (location > 0 && temp.compareTo(list[location - 1]) < 0); list[location] = (T) temp; } }//end insertionSort

Java Programming: Program Design Including Data Structures53  Average number of item assignments and key comparisons: Analysis: Insertion Sort

Java Programming: Program Design Including Data Structures54 Analysis: Insertion Sort (continued) Table 18-9 Average Case Behavior of the Bubble Sort, Selection Sort, and Insertion Sort Algorithms for a List of Length n

Java Programming: Program Design Including Data Structures55 Quick Sort: Array-Based Lists  General algorithm if (the list size is greater than 1) { a. Partition the list into two sublists, say lowerSublist and upperSublist. b. Quick sort lowerSublist. c. Quick sort upperSublist. d. Combine the sorted lowerSublist and sorted upperSublist. }

Java Programming: Program Design Including Data Structures56 Quick Sort: Array-Based Lists (continued) Figure list before the partition Figure list after the partition

Java Programming: Program Design Including Data Structures57 Quick Sort: Array-Based Lists (continued)  Method partition private int partition(T[] list, int first, int last) { T pivot; int smallIndex; swap(list, first, (first + last) / 2); pivot = list[first]; smallIndex = first; for (int index = first + 1; index <= last; index++) { Comparable compElem = (Comparable ) list[index]; if (compElem.compareTo(pivot) < 0) { smallIndex++; swap(list, smallIndex, index); } swap(list, first, smallIndex); return smallIndex; }//end partition

Java Programming: Program Design Including Data Structures58 Quick Sort: Array-Based Lists (continued)  Method swap and recQuickSort private void swap(T[] list, int first, int second) { T temp; temp = list[first]; list[first] = list[second]; list[second] = temp; }//end swap private void recQuickSort(T[] list, int first, int last) { if (first < last) { int pivotLocation = partition(list, first, last); recQuickSort(list, first, pivotLocation - 1); recQuickSort(list, pivotLocation + 1, last); } }//end recQuickSort

Java Programming: Program Design Including Data Structures59 Quick Sort: Array-Based Lists (continued)  Method quickSort public void quickSort(T[] list, int length) { recQuickSort(list, 0, length - 1); }//end quickSort

Java Programming: Program Design Including Data Structures60 Analysis: Quick Sort Table Analysis of the Quick Sort Algorithm for a List of Length n

Java Programming: Program Design Including Data Structures61 Merge Sort: Linked List-Based Lists  General algorithm if the list is of size greater than 1 { a. Divide the list into two sublists. b. Merge sort the first sublist. c. Merge sort the second sublist. d. Merge the first sublist and the second sublist. }

Java Programming: Program Design Including Data Structures62 Merge Sort: Linked List-Based Lists (continued) Figure Merge sort algorithm

Java Programming: Program Design Including Data Structures63 Divide  General steps  Find the middle node  Since you don’t know the size of the list, you have to traverse it until you reach the middle node  Divide the list into two sublists of nearly equal size

Java Programming: Program Design Including Data Structures64 Merge  General steps  Compare the elements of the sorted sublists  Adjust the references of the nodes with the smaller info

Java Programming: Program Design Including Data Structures65 Merge (continued)  Method recMergeSort private LinkedListNode recMergeSort(LinkedListNode head) { LinkedListNode otherHead; if (head != null) //if the list is not empty if (head.link != null) //if the list has more //than one node { otherHead = divideList(head); head = recMergeSort(head); otherHead = recMergeSort(otherHead); head = mergeList(head, otherHead); } return head; }//end recMergeSort

Java Programming: Program Design Including Data Structures66 Merge (continued)  Method mergeSort public void mergeSort() { first = recMergeSort(first); if (first == null) last = null; else { last = first; while (last.link != null) last = last.link; } } //end mergeSort

Java Programming: Program Design Including Data Structures67 Analysis: Merge Sort  The maximum number of comparisons is O(nlog 2 n)  This applies for both the worst and the average case

Java Programming: Program Design Including Data Structures68 Heap Sort: Array-Based Lists  A heap is a list in which each element contains a key  The key in the element at position k in the list is at least as large as the key in the element at position 2k + 1, and 2k + 2  Given a heap, you can construct a complete binary tree  After you convert the array into a heap, the sorting phase begins

Java Programming: Program Design Including Data Structures69 Heap Sort: Array-Based Lists (continued) Figure Complete binary tree corresponding to the list in Figure Figure A list that is a heap

Java Programming: Program Design Including Data Structures70 Build Heap  Method heapify private void heapify(T[] list, int low, int high) { int largeIndex; Comparable temp = (Comparable ) list[low]; //copy the root node of the subtree largeIndex = 2 * low + 1; //index of the left child while (largeIndex <= high) { if (largeIndex < high) { Comparable compElem = (Comparable ) list[largeIndex]; if (compElem.compareTo(list[largeIndex + 1]) < 0) largeIndex = largeIndex + 1; //index of the largest child }

Java Programming: Program Design Including Data Structures71 Build Heap (continued) if (temp.compareTo(list[largeIndex]) > 0) //subtree //is already in a heap break; else { list[low] = list[largeIndex]; //move the larger //child to the root low = largeIndex; //go to the subtree to //restore the heap largeIndex = 2 * low + 1; } }//end while list[low] = (T) temp; //insert temp into the tree, //that is, list }//end heapify

Java Programming: Program Design Including Data Structures72 Build Heap (continue)  Method buildHeap private void buildHeap(T[] list, int length) { for (int index = length / 2 - 1; index >= 0; index--) heapify(list, index, length - 1); }//end buildHeap

Java Programming: Program Design Including Data Structures73 Build Heap (continue)  Method heapSort public void heapSort(T[] list, int length) { buildHeap(list, length); for (int lastOutOfOrder = length - 1; lastOutOfOrder >= 0; lastOutOfOrder--) { T temp = list[lastOutOfOrder]; list[lastOutOfOrder] = list[0]; list[0] = temp; heapify(list, 0, lastOutOfOrder - 1); }//end for }//end heapSort

Java Programming: Program Design Including Data Structures74 Analysis: Heap Sort  Number of key comparisons in the worst case 2nlog 2 n + O(n) = O(nlog 2 n)  Number of item assignments in the worst case nlog 2 n + O(n) = O(nlog 2 n)  Number of key comparisons, average case 1.39nlog 2 n + O(n) = O(nlog 2 n)  Number of item assignments, average case 1.39nlog 2 n + O(n) = O(nlog 2 n)