Stacks, Queues, ListNodes

Slides:



Advertisements
Similar presentations
Garfield AP Computer Science
Advertisements

CSE 373: Data Structures and Algorithms
CSE 373: Data Structures and Algorithms
Simple Sorting Algorithms
1 TCSS 342, Winter 2005 Lecture Notes Sorting Weiss Ch. 8, pp
Simple Sorting Algorithms. 2 Bubble sort Compare each element (except the last one) with its neighbor to the right If they are out of order, swap them.
Computer Science Searching & Sorting.
CSE 373 Data Structures and Algorithms
CSE 373: Data Structures and Algorithms Lecture 6: Sorting 1.
1 CSE 373 Sorting 3: Merge Sort, Quick Sort reading: Weiss Ch. 7 slides created by Marty Stepp
Searching & Sorting Programming 2. Searching Searching is the process of determining if a target item is present in a list of items, and locating it A.
1 Searching and Sorting Searching algorithms with simple arrays Sorting algorithms with simple arrays –Selection Sort –Insertion Sort –Bubble Sort –Quick.
M180: Data Structures & Algorithms in Java Sorting Algorithms Arab Open University 1.
CSE 143 Lecture 16 Sorting reading: 13.1, slides created by Marty Stepp
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.
Searching and Sorting Searching algorithms with simple arrays
Sort Algorithm.
Prof. U V THETE Dept. of Computer Science YMA
Lecture 25: Searching and Sorting
Searching and Sorting.
Sorting Mr. Jacobs.
COP 3503 FALL 2012 Shayan Javed Lecture 16
Lecture 14 Searching and Sorting Richard Gesick.
Sorting Algorithms.
Simple Sorting Algorithms
CSc 110, Autumn 2017 Lecture 37: searching and sorting
Chapter 7 Sorting Spring 14
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
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
Quicksort analysis Bubble sort
Selection sort Given an array of length n,
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.
Sorting Algorithms Ellysa N. Kosinaya.
CSc 110, Spring 2017 Lecture 39: searching and sorting
Lecture 11 Searching and Sorting Richard Gesick.
CSE 154 Sorting reading: 13.3, 13.4
Adapted from slides by Marty Stepp and Stuart Reges
slides created by Marty Stepp
Sub-Quadratic Sorting Algorithms
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.
CS 101 – Oct. 21 Sorting Much-studied problem in CS – many ways to do it Given a list of data, need to arrange it “in order” Some methods do better based.
Merge and Count Merge and count step.
Building Java Programs Chapter 13
Merge and Count Merge and count step.
CSE 373: Data Structures and Algorithms
Merge and Count Merge and count step.
Simple Sorting Algorithms
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
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.
Simple Sorting Algorithms
Simple Sorting Algorithms
CSE 373 Sorting 2: Selection, Insertion, Shell Sort
Sorting Algorithms.
Presentation transcript:

Stacks, Queues, ListNodes ...

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.

Bogo sort bogo sort: Orders a list of values by repetitively shuffling them and checking if they are sorted. name comes from the word "bogus" The algorithm: Scan the list, seeing if it is sorted. If so, stop. Else, shuffle the values in the list and repeat. This sorting algorithm (obviously) has terrible performance! What is its runtime?

Bogo sort code // Places the elements of a into sorted order. public static void bogoSort(int[] a) { while (!isSorted(a)) { shuffle(a); } // Returns true if a's elements are in sorted order. public static boolean isSorted(int[] a) { for (int i = 0; i < a.length - 1; i++) { if (a[i] > a[i + 1]) { return false; return true;

Bogo sort code, cont'd. // Shuffles an array of ints by randomly swapping each // element with an element ahead of it in the array. public static void shuffle(int[] a) { for (int i = 0; i < a.length - 1; i++) { // pick a random index in [i+1, a.length-1] int range = a.length - 1 - (i + 1) + 1; int j = (int) (Math.random() * range + (i + 1)); swap(a, i, j); } // Swaps a[i] with a[j]. public static void swap(int[] a, int i, int j) { if (i != j) { int temp = a[i]; a[i] = a[j]; a[j] = temp;

Similar algorithms 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 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-array 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 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-array (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. 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

Merging sorted halves

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. An example of a "divide and conquer" algorithm. Invented by John von Neumann in 1945