Analysis of Algorithms

Slides:



Advertisements
Similar presentations
Md. Ahsan Arif, Assistant Professor, Dept. of CSE, AUB
Advertisements

Lecture: Algorithmic complexity
HST 952 Computing for Biomedical Scientists Lecture 10.
Algorithm Complexity Analysis: Big-O Notation (Chapter 10.4)
Fall 2006CENG 7071 Algorithm Analysis. Fall 2006CENG 7072 Algorithmic Performance There are two aspects of algorithmic performance: Time Instructions.
Chapter 3 Growth of Functions
Introduction to Analysis of Algorithms
Scott Grissom, copyright 2004 Chapter 5 Slide 1 Analysis of Algorithms (Ch 5) Chapter 5 focuses on: algorithm analysis searching algorithms sorting algorithms.
Cmpt-225 Algorithm Efficiency.
Algorithm Analysis CS 201 Fundamental Structures of Computer Science.
Analysis of Algorithms 7/2/2015CS202 - Fundamentals of Computer Science II1.
Analysis of Algorithm.
Analysis of Algorithms Spring 2015CS202 - Fundamentals of Computer Science II1.
Algorithm Analysis (Big O)
Time Complexity Dr. Jicheng Fu Department of Computer Science University of Central Oklahoma.
Analysis of Algorithm Lecture 3 Recurrence, control structure and few examples (Part 1) Huma Ayub (Assistant Professor) Department of Software Engineering.
Week 2 CS 361: Advanced Data Structures and Algorithms
1 Chapter 24 Developing Efficient Algorithms. 2 Executing Time Suppose two algorithms perform the same task such as search (linear search vs. binary search)
1 Recursion Algorithm Analysis Standard Algorithms Chapter 7.
Analysis of Algorithms
1 7.Algorithm Efficiency What to measure? Space utilization: amount of memory required  Time efficiency: amount of time required to process the data Depends.
1 COMP3040 Tutorial 1 Analysis of algorithms. 2 Outline Motivation Analysis of algorithms Examples Practice questions.
Chapter 10 A Algorithm Efficiency. © 2004 Pearson Addison-Wesley. All rights reserved 10 A-2 Determining the Efficiency of Algorithms Analysis of algorithms.
1 7.Algorithm Efficiency What to measure? Space utilization: amount of memory required  Time efficiency: amount of time required to process the data.
Analysis of Algorithms CSCI Previous Evaluations of Programs Correctness – does the algorithm do what it is supposed to do? Generality – does it.
Program Efficiency & Complexity Analysis. Algorithm Review An algorithm is a definite procedure for solving a problem in finite number of steps Algorithm.
Algorithm Analysis CS 400/600 – Data Structures. Algorithm Analysis2 Abstract Data Types Abstract Data Type (ADT): a definition for a data type solely.
CSC310 © Tom Briggs Shippensburg University Fundamentals of the Analysis of Algorithm Efficiency Chapter 2.
Algorithm Analysis Part of slides are borrowed from UST.
1 Chapter 2 Algorithm Analysis All sections. 2 Complexity Analysis Measures efficiency (time and memory) of algorithms and programs –Can be used for the.
1 Chapter 2 Algorithm Analysis Reading: Chapter 2.
Complexity of Algorithms Fundamental Data Structures and Algorithms Ananda Guna January 13, 2005.
Analysis of Algorithms Spring 2016CS202 - Fundamentals of Computer Science II1.
Chapter 15 Running Time Analysis. Topics Orders of Magnitude and Big-Oh Notation Running Time Analysis of Algorithms –Counting Statements –Evaluating.
Algorithm Complexity Analysis (Chapter 10.4) Dr. Yingwu Zhu.
1 7.Algorithm Efficiency These factors vary from one machine/compiler (platform) to another  Count the number of times instructions are executed So, measure.
Data Structures I (CPCS-204) Week # 2: Algorithm Analysis tools Dr. Omar Batarfi Dr. Yahya Dahab Dr. Imtiaz Khan.
Algorithm Analysis 1.
Algorithm Efficiency and Sorting
CS 302 Data Structures Algorithm Efficiency.
Chapter 2 Algorithm Analysis
Mathematical Foundation
Introduction to Analysis of Algorithms
Analysis of Algorithms
Analysis of Algorithms
GC 211:Data Structures Week 2: Algorithm Analysis Tools
Analysis of Algorithms
Introduction to Algorithms
Algorithm Analysis CSE 2011 Winter September 2018.
CS 3343: Analysis of Algorithms
Time Complexity Analysis Neil Tang 01/19/2010
Algorithm Analysis Neil Tang 01/22/2008
Algorithm Analysis (not included in any exams!)
Algorithm design and Analysis
Asymptotic Notations Algorithms Lecture 9.
What is CS 253 about? Contrary to the wide spread belief that the #1 job of computers is to perform calculations (which is why the are called “computers”),
Algorithm Efficiency Chapter 10.
Data Structures Review Session
CS 201 Fundamental Structures of Computer Science
Programming and Data Structure
Algorithm Efficiency and Sorting
Analysis of Algorithms
DS.A.1 Algorithm Analysis Chapter 2 Overview
Programming and Data Structure
Algorithm Analysis Bina Ramamurthy CSE116A,B.
GC 211:Data Structures Algorithm Analysis Tools
Fundamentals of the Analysis of Algorithm Efficiency
At the end of this session, learner will be able to:
Algorithm Efficiency and Sorting
Algorithms and data structures: basic definitions
Presentation transcript:

Analysis of Algorithms Initially prepared by Dr. İlyas Çiçekli; improved by various Bilkent CS202 instructors. Spring 2019 CS202 - Fundamentals of Computer Science II

lec03-algorithmanalysis August 5, 2019 Algorithm An algorithm is a set of instructions to be followed to solve a problem. There can be more than one solution (more than one algorithm) to solve a given problem. An algorithm can be implemented using different prog. languages on different platforms. Once we have a correct algorithm for the problem, we have to determine the efficiency of that algorithm. How much time that algorithm requires. How much space that algorithm requires. We will focus on How to estimate the time required for an algorithm How to reduce the time required Spring 2019 CS202 - Fundamentals of Computer Science II

Analysis of Algorithms How do we compare the time efficiency of two algorithms that solve the same problem? We should employ mathematical techniques that analyze algorithms independently of specific implementations, computers, or data. To analyze algorithms: First, we start counting the number of significant operations in a particular solution to assess its efficiency. Then, we will express the efficiency of algorithms using growth functions. Spring 2019 CS202 - Fundamentals of Computer Science II

Analysis of Algorithms Simple instructions (+,-,*,/,=,if,call) take 1 step Loops and subroutine calls are not simple operations They depend on size of data and the subroutine “sort” is not a single step operation Complex Operations (matrix addition, array resizing) are not single step We assume infinite memory We do not include the time required to read the input Spring 2019 CS202 - Fundamentals of Computer Science II

The Execution Time of Algorithms Consecutive statements count = count + 1; sum = sum + count; Total cost = 1 + 1  The time required for this algorithm is constant Times 1 Don’t forget: We assume that each simple operation takes one unit of time Spring 2019 CS202 - Fundamentals of Computer Science II

The Execution Time of Algorithms If-else statements if (n < 0){ absval = -n cout << absval; } else absval = n; Total Cost <= 1 + max(2,1) Times 1 Spring 2019 CS202 - Fundamentals of Computer Science II

The Execution Time of Algorithms Single loop statements i = 1; sum = 0; while (i <= n) { i = i + 1; sum = sum + i; } Times 1 n+1 n Total cost = 1 + 1 + (n + 1) + n + n  The time required for this algorithm is proportional to n Spring 2019 CS202 - Fundamentals of Computer Science II

The Execution Time of Algorithms Nested loop statements i = 1; sum = 0; while (i <= n) { j=1; while (j <= n) { sum = sum + i; j = j + 1; } i = i +1; Times 1 n+1 n n * (n+1) n * n Total cost = 1 + 1 + (n + 1) + n + n * (n + 1) + n * n + n * n + n  The time required for this algorithm is proportional to n2 Spring 2019 CS202 - Fundamentals of Computer Science II

Algorithm Growth Rates We measure the time requirement of an algorithm as a function of the problem size. The most important thing is to learn how quickly the time requirement of an algorithm grows as a function of the problem size. An algorithm’s proportional time requirement is known as growth rate. We can compare the efficiency of two algorithms by comparing their growth rates. The time requirement as a function of the problem size n Spring 2019 CS202 - Fundamentals of Computer Science II

Order-of-Magnitude Analysis and Big-O Notation If Algorithm A requires time at most proportional to f(n), it is said to be order f(n), and it is denoted as O(f(n)) f(n) is called the algorithm’s growth-rate function Since the capital O is used in the notation, this notation is called the Big-O notation Spring 2019 CS202 - Fundamentals of Computer Science II

CS202 - Fundamentals of Computer Science II Big-O Notation Definition: Algorithm A is order of if it requires no more than time units to solve a problem of size There may exist many values of c and n0 More informally, is an upper bound on Spring 2019 CS202 - Fundamentals of Computer Science II

O-notation: Asymptotic upper bound T(n) = O(f(n)) if  positive constants c, n0 such that 0 ≤ T(n) ≤ cf(n), n ≥ n0 cf(n) Asymptotic running times of algorithms are usually defined by functions whose domain are N={0, 1, 2, …} (natural numbers) T(n) = O(f(n)) T(n)

CS202 - Fundamentals of Computer Science II Big-O Notation c1*f(n) c*f(n) T(n) T(n) T(n) c*f(n) c2*f(n) O(f(n)) Ω(f(n)) Θ(f(n)) Big-O definition implies: constant n0 beyond which it is satisfied We do not care about small values of n Spring 2019 CS202 - Fundamentals of Computer Science II

Example Show that 2n2 = O(n3) We need to find two positive constants: c and n0 such that: 0 ≤ 2n2 ≤ cn3 for all n ≥ n0 Choose c = 2 and n0 = 1  2n2 ≤ 2n3 for all n ≥ 1 Or, choose c = 1 and n0 = 2  2n2 ≤ n3 for all n ≥ 2

Example Show that 2n2 + n = O(n2) We need to find two positive constants: c and n0 such that: 0 ≤ 2n2 + n ≤ cn2 for all n ≥ n0 2 + (1/n) ≤ c for all n ≥ n0 Choose c = 3 and n0 = 1  2n2 + n ≤ 3n2 for all n ≥ 1

CS202 - Fundamentals of Computer Science II Example Show that is order of Show that there exist constants c and n0 that satisfy the condition Try c = 3 and n0 = 2 Spring 2019 CS202 - Fundamentals of Computer Science II

True or False? True 109n2 = O (n2) True False 10-9n2.0001 = O (n2) Choose c = 109 and n0 = 1 109n2 = O (n2) 0 ≤ 109n2 ≤ 109n2 for n ≥1 Choose c = 100 and n0 = 1 True 100n1.9999 = O (n2) 0 ≤ 100n1.9999 ≤ 100n2 for n≥1 10-9n2.0001 ≤ cn2 for n ≥ n0 False 10-9n2.0001 = O (n2) 10-9 n0.0001 ≤ c for n ≥ n0 Contradiction

A Comparison of Growth-Rate Functions Spring 2019 CS202 - Fundamentals of Computer Science II

A Comparison of Growth-Rate Functions Spring 2019 CS202 - Fundamentals of Computer Science II

A Comparison of Growth-Rate Functions Any algorithm with n! complexity is useless for n>=20 Algorithms with 2n running time is impractical for n>=40 Algorithms with n2 running time is usable up to n=10,000 But not useful for n>1,000,000 Linear time (n) and n log n algorithms remain practical even for one billion items Algorithms with log n complexity is practical for any value of n Spring 2019 CS202 - Fundamentals of Computer Science II

Properties of Growth-Rate Functions We can ignore the low-order terms If an algorithm is O(n3+4n2+3n), it is also O(n3) Use only the highest-order term to determine its grow rate We can ignore a multiplicative constant in the highest-order term If an algorithm is O(5n3), it is also O(n3) O( f(n) ) + O( g(n) ) = O( f(n) + g(n) ) If an algorithm is O(n3) + O(4n2), it is also O(n3 +4n2)  So, it is O(n3) Similar rules hold for multiplication Spring 2019 CS202 - Fundamentals of Computer Science II

Some Useful Mathematical Equalities Spring 2019 CS202 - Fundamentals of Computer Science II

Growth-Rate Functions Remember our previous examples Times i = 1; 1 sum = 0; 1 while (i <= n) { n + 1 i = i + 1; n sum = sum + i; n } Total cost = 1 + 1 + (n + 1) + n + n = 3 * n + 3  The time required for this algorithm is proportional to n  The growth-rate of this algorithm is proportional to O(n) Spring 2019 CS202 - Fundamentals of Computer Science II

Growth-Rate Functions Times i = 1; 1 sum = 0; 1 while (i <= n) { n + 1 j=1; n while (j <= n) { n * (n + 1) sum = sum + i; n * n j = j + 1; n * n } i = i +1; n Total cost = 1 + 1 + (n + 1) + n + n * (n + 1) + n * n + n * n + n Total cost = 3 * n2 + 4 * n + 3  The time required for this algorithm is proportional to n2  The growth-rate of this algorithm is proportional to O(n2) Spring 2019 CS202 - Fundamentals of Computer Science II

CS202 - Fundamentals of Computer Science II What to Analyze Worst-case performance It is an upper bound for any input Its use is more common than the others Best-case performance This is useless! Why? Average-case performance It is valid if you can figure out what the “average” input is It is computed considering all possible inputs and their distribution It is usually difficult to compute Spring 2019 CS202 - Fundamentals of Computer Science II

CS202 - Fundamentals of Computer Science II Consider the sequential search algorithm int sequentialSearch(const int a[], int item, int n){ for (int i = 0; i < n; i++) if (a[i] == item) return i; return -1; } Worst-case: If the item is in the last location of the array or If it is not found in the array Best-case: If the item is in the first location of the array Average-case: How can we compute it? Spring 2019 CS202 - Fundamentals of Computer Science II

How to find the growth-rate of C++ codes? Spring 2019 CS202 - Fundamentals of Computer Science II

CS202 - Fundamentals of Computer Science II Some Examples Solved on the Board. Spring 2019 CS202 - Fundamentals of Computer Science II

What about recursive functions? Spring 2019 CS202 - Fundamentals of Computer Science II

CS202 - Fundamentals of Computer Science II Consider the problem of Hanoi towers void hanoi(int n, char source, char dest, char spare) { if (n > 0) { hanoi(n - 1, source, spare, dest); move from source to dest hanoi(n - 1, spare, dest, source); } How do we find the growth-rate of the recursive hanoi function? First write a recurrence equation for the hanoi function Then solve the recurrence equation There are many methods to solve recurrence equations We will learn a simple one known as repeated substitutions http://www.cut-the-knot.org/recurrence/hanoi.shtml Spring 2019 CS202 - Fundamentals of Computer Science II

CS202 - Fundamentals of Computer Science II Let’s first write a recurrence equation for the hanoi function We will then solve it by using repeated substitutions Spring 2019 CS202 - Fundamentals of Computer Science II

CS202 - Fundamentals of Computer Science II More examples Factorial function Binary search Merge sort – later Spring 2019 CS202 - Fundamentals of Computer Science II