Adapted from slides by Marty Stepp and Stuart Reges

Slides:



Advertisements
Similar presentations
Garfield AP Computer Science
Advertisements

Sorting Algorithms Nelson Padua-Perez Bill Pugh Department of Computer Science University of Maryland, College Park.
CSE 373: Data Structures and Algorithms
CSE 373: Data Structures and Algorithms
1 TCSS 342, Winter 2005 Lecture Notes Sorting Weiss Ch. 8, pp
Sorting Algorithms Fawzi Emad Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
CS 104 Introduction to Computer Science and Graphics Problems Data Structure & Algorithms (3) Recurrence Relation 11/11 ~ 11/14/2008 Yang Song.
Sorting and Searching Arrays CSC 1401: Introduction to Programming with Java Week 12 – Lectures 1 & 2 Wanda M. Kunkle.
Sorting (Part II: Divide and Conquer) CSE 373 Data Structures Lecture 14.
Fall 2013 Instructor: Reza Entezari-Maleki Sharif University of Technology 1 Fundamentals of Programming Session 17 These.
Computer Science Searching & Sorting.
CSE 373 Data Structures and Algorithms
CSE 373: Data Structures and Algorithms Lecture 6: Sorting 1.
Sorting. Pseudocode of Insertion Sort Insertion Sort To sort array A[0..n-1], sort A[0..n-2] recursively and then insert A[n-1] in its proper place among.
CSE 341 Lecture 4 merge sort; basic efficiency issues Ullman slides created by Marty Stepp
Survey of Sorting Ananda Gunawardena. Naïve sorting algorithms Bubble sort: scan for flips, until all are fixed Etc...
CS 361 – Chapters 8-9 Sorting algorithms –Selection, insertion, bubble, “swap” –Merge, quick, stooge –Counting, bucket, radix How to select the n-th largest/smallest.
Sort Algorithms.
1 CSE 373 Sorting 3: Merge Sort, Quick Sort reading: Weiss Ch. 7 slides created by Marty Stepp
Searching and Sorting Recursion, Merge-sort, Divide & Conquer, Bucket sort, Radix sort Lecture 5.
1 Searching and Sorting Searching algorithms with simple arrays Sorting algorithms with simple arrays –Selection Sort –Insertion Sort –Bubble Sort –Quick.
ICS201 Lecture 21 : Sorting King Fahd University of Petroleum & Minerals College of Computer Science & Engineering Information & Computer Science Department.
CSE 143 Lecture 16 Sorting reading: 13.1, slides created by Marty Stepp
PREVIOUS SORTING ALGORITHMS  BUBBLE SORT –Time Complexity: O(n 2 ) For each item, make (n –1) comparisons Gives: Comparisons = (n –1) + (n – 2)
Building Java Programs Chapter 13 Searching and Sorting Copyright (c) Pearson All rights reserved.
Building Java Programs Chapter 13 Sorting reading: 13.3, 13.4.
Sorting and Runtime Complexity CS255. Sorting Different ways to sort: –Bubble –Exchange –Insertion –Merge –Quick –more…
Searching and Sorting Searching algorithms with simple arrays
Lecture 25: Searching and Sorting
Fundamentals of Algorithms MCS - 2 Lecture # 11
Searching and Sorting Algorithms
COP 3503 FALL 2012 Shayan Javed Lecture 16
Adapted from slides by Marty Stepp and Stuart Reges
CSc 110, Autumn 2017 Lecture 37: searching and sorting
slides created by Marty Stepp and Hélène Martin
Adapted from slides by Marty Stepp and Stuart Reges
Adapted from slides by Marty Stepp and Stuart Reges
Adapted from slides by Marty Stepp and Stuart Reges
Based on slides created by Ethan Apter & Marty Stepp
CSc 110, Spring 2017 Lecture 39: searching.
Building Java Programs
slides adapted from Marty Stepp and Hélène Martin
Building Java Programs
Merge sort merge sort: Repeatedly divides the data in half, sorts each half, and combines the sorted halves into a sorted whole. The algorithm: Divide.
“Human Sorting” It’s a “Problem Solving” game:
Sorting Algorithms Ellysa N. Kosinaya.
CSc 110, Spring 2017 Lecture 39: searching and sorting
CSE 154 Sorting reading: 13.3, 13.4
Adapted from slides by Marty Stepp and Stuart Reges
slides created by Marty Stepp
slides adapted from Marty Stepp
slides created by Marty Stepp and Ethan Apter
slides created by Marty Stepp
slides created by Marty Stepp
CSE 143 Sorting reading: 13.3, 13.4.
CSE 332: Data Abstractions Sorting I
Lecture 15: Algorithms AP Computer Science Principles
Building Java Programs Chapter 13
CSE 373: Data Structures and Algorithms
Adapted from slides by Marty Stepp and Stuart Reges
CSE 373 Data Structures and Algorithms
slides created by Marty Stepp and Hélène Martin
Building Java Programs
slides adapted from Marty Stepp
CSE 373 Sorting 1: Bogo Sort, Stooge Sort, Bubble Sort
Lecture 21: Searching and Sorting
Merge sort merge sort: Repeatedly divides the data in half, sorts each half, and combines the sorted halves into a sorted whole. The algorithm: Divide.
CSE 373 Sorting 2: Selection, Insertion, Shell Sort
“Human Sorting” It’s a “Problem Solving” game:
Stacks, Queues, ListNodes
Presentation transcript:

Adapted from slides by Marty Stepp and Stuart Reges CSc 110, Autumn 2017 Lecture 38: Sorting Adapted from slides by Marty Stepp and Stuart Reges

Sorting sorting: Rearranging the values in a list into a specific order (usually into their "natural ordering"). one of the fundamental problems in computer science can be solved in many ways: there are many sorting algorithms some are faster/slower than others some use more/less memory than others some work better with specific kinds of data some can utilize multiple computers / processors, ... comparison-based sorting : determining order by comparing pairs of elements: <, >, …

Selection sort selection sort: Orders a list of values by repeatedly putting the smallest or largest unplaced value into its final position. The algorithm: Look through the list to find the smallest value. Swap it so that it is at index 0. Look through the list to find the second-smallest value. Swap it so that it is at index 1. ... Repeat until all values are in their proper places.

Selection sort example Initial list: After 1st, 2nd, and 3rd passes: index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value 22 18 -4 27 30 36 50 68 91 56 85 42 98 25 index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value -4 18 22 27 30 36 50 68 91 56 85 42 98 25 index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value -4 22 27 30 36 50 68 91 56 18 85 42 98 25 index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value -4 22 27 30 36 50 68 91 56 18 85 42 98 25

Selection sort code # Rearranges the elements of a into sorted order using # the selection sort algorithm. def selection_sort(a): for i in range(0, len(a) - 1): # find index of smallest remaining value min = i for j in range(i + 1, len(a)): if (a[j] < a[min]): min = j # swap smallest value its proper place, a[i] swap(a, i, min)

Selection sort runtime (Fig. 13.6) How many comparisons does selection sort have to do?

Activity Initial list: After 1st, 2nd, and 3rd passes: index 1 2 3 4 5 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value -2 -6 50 70 -8 21 42 -5 index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value -8 -2 -6 50 70 21 42 -5 index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value -8 -6 -2 50 70 21 42 -5 index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value -8 -6 -5 50 70 21 42 -2

Similar algorithms bubble sort: Make repeated passes, swapping adjacent values slower than selection sort (has to do more swaps) insertion sort: Shift each element into a sorted sub-list faster than selection sort (examines fewer values) index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value 22 18 -4 27 30 36 50 68 91 56 85 42 98 25 index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value 18 -4 22 27 30 36 50 68 56 85 42 91 25 98 22 50 91 98 index 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 value -4 18 22 27 30 36 50 68 91 56 85 42 98 25 sorted sub-list (indexes 0-7) 7

Merge sort merge sort: Repeatedly divides the data in half, sorts each half, and combines the sorted halves into a sorted whole. The algorithm: Divide the list into two roughly equal halves. Sort the left half. Sort the right half. Merge the two sorted halves into one sorted list. Often implemented recursively. An example of a "divide and conquer" algorithm. Invented by John von Neumann in 1945

Merge sort example index 1 2 3 4 5 6 7 value 22 18 12 -4 58 31 42 22 1 2 3 4 5 6 7 value 22 18 12 -4 58 31 42 split 22 18 12 -4 58 7 31 42 split split 22 18 12 -4 58 7 31 42 split split split split 22 18 12 -4 58 7 31 42 merge merge merge merge 18 22 -4 12 7 58 31 42 merge merge -4 12 18 22 7 31 42 58 merge -4 7 12 18 22 31 42 58

Merge halves code # Merges the left/right elements into a sorted result. # Precondition: left/right are sorted def merge(result, left, right): i1 = 0 # index into left list i2 = 0 # index into right list for i in range(0, len(result)): if i2 >= len(right) or (i1 < len(left) and left[i1] <= right[i2]): result[i] = left[i1] # take from left i1 += 1 else: result[i] = right[i2] # take from right i2 += 1

Merge sort code # Rearranges the elements of a into sorted order using # the merge sort algorithm. def merge_sort(a): if len(a) >= 2: # split list into two halves left = a[0, len(a)//2] right = a[len(a)//2, len(a)] # sort the two halves merge_sort(left) merge_sort(right) # merge the sorted halves into a sorted whole merge(a, left, right)

Merge sort runtime How many comparisons does merge sort have to do?

Activity merge sort the following list: index 1 2 3 4 5 6 7 value 11 1 2 3 4 5 6 7 value 11 -8 42

Sorting algorithms bogo sort: shuffle and pray bubble sort: swap adjacent pairs that are out of order selection sort: look for the smallest element, move to front insertion sort: build an increasingly large sorted front portion merge sort: recursively divide the list in half and sort it heap sort: place the values into a sorted tree structure quick sort: recursively partition list based on a middle value other specialized sorting algorithms: bucket sort: cluster elements into smaller groups, sort them radix sort: sort integers by last digit, then 2nd to last, then ... ...