CSC 421: Algorithm Design & Analysis

Slides:



Advertisements
Similar presentations
110/6/2014CSE Suprakash Datta datta[at]cse.yorku.ca CSE 3101: Introduction to the Design and Analysis of Algorithms.
Advertisements

Chapter 11 Limitations of Algorithm Power Copyright © 2007 Pearson Addison-Wesley. All rights reserved.
Lower Bounds for Sorting, Searching and Selection
CS420 lecture one Problems, algorithms, decidability, tractability.
Transform & Conquer Replacing One Problem With Another Saadiq Moolla.
Chapter 6: Transform and Conquer
Algorithms Recurrences. Definition – a recurrence is an equation or inequality that describes a function in terms of its value on smaller inputs Example.
CSC 2300 Data Structures & Algorithms March 27, 2007 Chapter 7. Sorting.
Chapter 11: Limitations of Algorithmic Power
DAST 2005 Week 4 – Some Helpful Material Randomized Quick Sort & Lower bound & General remarks…
Chapter 11 Limitations of Algorithm Power Copyright © 2007 Pearson Addison-Wesley. All rights reserved.
CSE 373 Data Structures Lecture 15
1 CSC 421: Algorithm Design & Analysis Spring 2013 Complexity & Computability  lower bounds on problems brute force, decision trees, adversary arguments,
Chapter 11 Limitations of Algorithm Power. Lower Bounds Lower bound: an estimate on a minimum amount of work needed to solve a given problem Examples:
CSCE350 Algorithms and Data Structure
A. Levitin “Introduction to the Design & Analysis of Algorithms,” 3rd ed., Ch. 11 ©2012 Pearson Education, Inc. Upper Saddle River, NJ. All Rights Reserved.
Computational Complexity Polynomial time O(n k ) input size n, k constant Tractable problems solvable in polynomial time(Opposite Intractable) Ex: sorting,
Analysis of Algorithms
The Lower Bounds of Problems
1 Lower Bounds Lower bound: an estimate on a minimum amount of work needed to solve a given problem Examples: b number of comparisons needed to find the.
Limits to Computation How do you analyze a new algorithm? –Put it in the form of existing algorithms that you know the analysis. –For example, given 2.
Solving Recurrences with the Substitution Method.
LIMITATIONS OF ALGORITHM POWER
CSCE 411H Design and Analysis of Algorithms Set 10: Lower Bounds Prof. Evdokia Nikolova* Spring 2013 CSCE 411H, Spring 2013: Set 10 1 * Slides adapted.
1 CSC 421: Algorithm Design & Analysis Spring 2014 Complexity & lower bounds  brute force  decision trees  adversary arguments  problem reduction.
CS216: Program and Data Representation University of Virginia Computer Science Spring 2006 David Evans Lecture 8: Crash Course in Computational Complexity.
Big O David Kauchak cs302 Spring Administrative Assignment 1: how’d it go? Assignment 2: out soon… Lab code.
Sorting Lower Bounds n Beating Them. Recap Divide and Conquer –Know how to break a problem into smaller problems, such that –Given a solution to the smaller.
Sorting & Lower Bounds Jeff Edmonds York University COSC 3101 Lecture 5.
CSC 421: Algorithm Design & Analysis
CSC 421: Algorithm Design Analysis
CSC 421: Algorithm Design Analysis
David Kauchak cs062 Spring 2010
Sorting Lower Bound 4/25/2018 8:49 PM
Advanced Algorithms Analysis and Design
Analysis of Algorithms
CSE15 Discrete Mathematics 03/13/17
Decision trees Polynomial-Time
Chapter 6 Transform-and-Conquer
Randomized Algorithms
CPSC 411 Design and Analysis of Algorithms
Introduction to Algorithms
Growth of functions CSC317.
Optimal Algorithms Search and Sort.
CS 3343: Analysis of Algorithms
CSCE 411 Design and Analysis of Algorithms
CS 3343: Analysis of Algorithms
(2,4) Trees 11/15/2018 9:25 AM Sorting Lower Bound Sorting Lower Bound.
Chapter 6 Transform and Conquer.
Lower Bound Theory.
Analysis and design of algorithm
CSCE 411 Design and Analysis of Algorithms
CS 3343: Analysis of Algorithms
Randomized Algorithms
(2,4) Trees 12/4/2018 1:20 PM Sorting Lower Bound Sorting Lower Bound.
Divide-and-Conquer 7 2  9 4   2   4   7
Chapter 6: Transform and Conquer
Chapter 11 Limitations of Algorithm Power
3. Brute Force Selection sort Brute-Force string matching
Transform and Conquer Transform and Conquer Transform and Conquer.
(2,4) Trees 2/28/2019 3:21 AM Sorting Lower Bound Sorting Lower Bound.
3. Brute Force Selection sort Brute-Force string matching
Divide-and-Conquer 7 2  9 4   2   4   7
Transform and Conquer Transform and Conquer Transform and Conquer.
CPSC 411 Design and Analysis of Algorithms
Introduction To Algorithms
CSC 421: Algorithm Design & Analysis
Divide-and-Conquer 7 2  9 4   2   4   7
Complexity Theory: Foundations
3. Brute Force Selection sort Brute-Force string matching
Presentation transcript:

CSC 421: Algorithm Design & Analysis Spring 2015 Complexity & lower bounds brute force decision trees adversary arguments problem reduction

Lower bounds on problems when studying a problem, may wish to establish a lower bound on efficiency for searching a sorted list, can we do better than binary search? O(log N for sorting a list, can we do better than merge/quick/heap sorts? O(N log N) establishing a lower bound for a problem can tell us when a particular algorithm is as good as possible when the problem is intractable (by showing that best possible algorithm is BAD) methods for establishing lower bounds: brute force information-theoretic arguments (decision trees) adversary arguments problem reduction

Brute force arguments sometimes, a problem-specific approach works example: polynomial evaluation p(N) = aNxN + aN-1xN-1 + … + a0 evaluating this polynomial requires Ω(N) steps, since each coefficient must be processed example: Towers of Hanoi puzzle can prove, by induction, that moving a tower of size N requires Ω(2N) steps

Information-theoretic arguments can sometimes establish a lower bound based on the amount of information the solution must produce example: guess a randomly selected number between 1 and N with possible responses of "correct", "too low", or "too high" the amount of uncertainty is log2 N, the number of bits needed to specify the selected largest number e.g., N = 127  7 bits each answer to a question yields at most 1 bit of information if guess of 64 yields “too high,” then 1st bit must be a 0  0xxxxxx if next guess of 32 yields “too low,”, then 2nd bit must be 1  01xxxxx if next guess of 48 yields “too low,” then 3rd bit must be 1  011xxxx . . . thus, log2 N is a lower bound on the number of questions

Decision trees a useful structure for information-theoretic arguments is a decision tree example: guessing a number between 1 and 15 8? 4? 12? 2? 6? high? 0xxx low? 1xxx 00xx 01xx 10xx 11xx 0001 0011 0010 1000 0100 1100 0101 0111 0110 10? 14? 1001 1011 1010 1101 1111 1110

Decision trees in general, a decision tree is a model of algorithms involving comparisons internal nodes represent comparisons leaves represent outcomes e.g., decision tree for 3-element insertion sort:

Decision trees & sorting note that any comparison-based sorting algorithm can be represented by a decision tree number of leaves (outcomes)  N! height of binary tree with N! leaves  log2 N! therefore, the minimum number of comparisons required by any comparison-based sorting algorithm  log2 N! since log2 N!  N log2 N (proof not shown), the lower bound Ω(N log N) is tight thus, merge/quick/heap sorts are as good as it gets

Decision trees & searching similarly, we can use a decision tree to show that binary search is as good as it gets (assuming the list is sorted) decision tree for binary search of 4-element list: internal nodes are found elements leaves are ranges if not found number of leaves (ranges where not found) = N + 1 height of binary tree with N+1 leaves  log2 (N+1) therefore, the minimum number of comparisons required by any comparison-based searching algorithm  log2 (N+1) lower bound Ω(log N) is tight

Adversary arguments using an adversary argument, you repeatedly adjust the input to make an algorithm work the hardest example: dishonest hangman adversary always puts the word in a larger of the subset generated by last guess for a given dictionary, can determine a lower bound on guesses example: merging two sorted lists of size N (as in merge sort) adversary makes it so that no list "runs out" of values (e.g., ai < bj iff i < j) forces 2N-1 comparisons to produce b1 < a1 < b2 < a2 < … < bN < aN

Problem reduction problem reduction uses a transform & conquer approach if we can show that problem P is at least as hard as problem Q, then a lower bound for Q is also a lower bound for P. i.e., hard(P) ≥ hard(Q)  if Q is Ω(X), so is P in general, to prove lower bound for P: find problem Q with a known lower bound reduce that problem to problem P i.e., show that can solve Q by solving an instance of P then P is at least as hard as Q, so same lower bound applies example: prove that multiplication (of N-bit numbers) is Ω(N) squaring an N-bit number is known to be Ω(N) can reduce squaring to multiplication: x2 = x * x then multiplication is at least as hard as squaring, so also Ω(N) REASONING: if multiplication could be solved in O(X) where X < N, then could do x2 by doing x*x  O(X) < O(N) CONTRADICTION OF SQUARE'S Ω(N)

Problem reduction example CLOSEST NUMBERS (CN) PROBLEM: given N numbers, find the two closest numbers consider the ELEMENT UNIQUENESS (EU) problem given a list of N numbers, determine if all are unique (no dupes) this problem has been shown to have a lower bound of Ω(N log N) can reduce EU to CN consider an instance of EU: given numbers e1, …, eN, determine if all are unique find the two closest numbers (this is an instance of CN) if the distance between them is > 0, then e1, …, eN are unique this shows that CN is at least as hard as EU can solve an instance of EU by performing a transformation & solving CN since transformation is O(N), CN must also have a lower-bound of Ω(N log N) REASONING: if CN could be solved in O(X) where X < N log N, then could solve EU by transforming & solving CN  O(N) +O(X) < O(N log N) CONTRADICTION OF EU's Ω(N log N)

Another example CLOSEST POINTS (CP) PROBLEM: given N points in the plane, find the two closest points consider the CLOSEST NUMBER (CN) problem we just showed that CN has a lower bound of Ω(N log N) can reduce CN to CP consider an instance of CN: given numbers e1, …, eN, determine closest numbers from these N numbers, construct N points: (e1, 0), …, (eN, 0) find the two closest points (this is an instance of CP) if (ei, 0) and (ej, 0) are closest points, then ei and ej are closest numbers this shows that CP is at least as hard as CN can solve an instance of CN by performing a transformation & solving CP since transformation is O(N), CP must also have a lower-bound of Ω(N log N) REASONING: if CP could be solved in O(X) where X < N log N, then could solve CN by transforming & solving CP  O(N) +O(X) < O(N log N) CONTRADICTION OF CN's Ω(N log N)

Tightness note: if an algorithm is Ω(N log N), then it is also Ω(N) are the Ω(N log N) lower bounds tight for CLOSEST NUMBERS and CLOSEST POINTS problems? can you devise O(N log N) algorithm for CLOSEST NUMBERS? can you devise O(N log N) algorithm for CLOSEST POINTS?