Algorithm Complexity Analysis: Big-O Notation (Chapter 10.4)

Slides:



Advertisements
Similar presentations
Algorithm Analysis.
Advertisements

Fall 2006CENG 7071 Algorithm Analysis. Fall 2006CENG 7072 Algorithmic Performance There are two aspects of algorithmic performance: Time Instructions.
Introduction to Analysis of Algorithms
Complexity Analysis (Part I)
Complexity Analysis (Part II)
CISC220 Spring 2010 James Atlas Lecture 06: Linked Lists (2), Big O Notation.
Analysis of Algorithms1 Estimate the running time Estimate the memory space required. Time and space depend on the input size.
The Efficiency of Algorithms
Algorithm Analysis CS 201 Fundamental Structures of Computer Science.
Data Structure Algorithm Analysis TA: Abbas Sarraf
Analysis of Algorithms 7/2/2015CS202 - Fundamentals of Computer Science II1.
Lecture 3 Feb 7, 2011 Goals: Chapter 2 (algorithm analysis) Examples: Selection sorting rules for algorithm analysis Image representation Image processing.
Analysis of Algorithms COMP171 Fall Analysis of Algorithms / Slide 2 Introduction * What is Algorithm? n a clearly specified set of simple instructions.
Analysis of Algorithms Spring 2015CS202 - Fundamentals of Computer Science II1.
Algorithm Analysis (Big O)
Spring2012 Lecture#10 CSE 246 Data Structures and Algorithms.
Liang, Introduction to Java Programming, Seventh Edition, (c) 2009 Pearson Education, Inc. All rights reserved Chapter 23 Algorithm Efficiency.
Algorithm Analysis & Complexity We saw that a linear search used n comparisons in the worst case (for an array of size n) and binary search had logn comparisons.
Program Performance & Asymptotic Notations CSE, POSTECH.
Week 2 CS 361: Advanced Data Structures and Algorithms
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved ADT Implementation:
C. – C. Yao Data Structure. C. – C. Yao Chap 1 Basic Concepts.
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved ADT Implementation:
1 Sorting Algorithms (Basic) Search Algorithms BinaryInterpolation Big-O Notation Complexity Sorting, Searching, Recursion Intro to Algorithms Selection.
1 Chapter 24 Developing Efficient Algorithms. 2 Executing Time Suppose two algorithms perform the same task such as search (linear search vs. binary search)
Introduction to complexity. 2 Analysis of Algorithms Why do we need to analyze algorithms? –To measure the performance –Comparison of different algorithms.
1 Recursion Algorithm Analysis Standard Algorithms Chapter 7.
Data Structures and Algorithms Lecture 5 and 6 Instructor: Quratulain Date: 15 th and 18 th September, 2009 Faculty of Computer Science, IBA.
Analysis of Algorithms
Analysis of Algorithm Efficiency Dr. Yingwu Zhu p5-11, p16-29, p43-53, p93-96.
1 7.Algorithm Efficiency What to measure? Space utilization: amount of memory required  Time efficiency: amount of time required to process the data Depends.
C++ Programming: From Problem Analysis to Program Design, Second Edition Chapter 19: Searching and Sorting.
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.
Chapter 10 Algorithm Analysis.  Introduction  Generalizing Running Time  Doing a Timing Analysis  Big-Oh Notation  Analyzing Some Simple Programs.
Computer Science and Software Engineering University of Wisconsin - Platteville 8. Comparison of Algorithms Yan Shi CS/SE 2630 Lecture Notes Part of this.
Algorithm Analysis Part of slides are borrowed from UST.
Algorithm Analysis (Big O)
Complexity Analysis. 2 Complexity The complexity of an algorithm quantifies the resources needed as a function of the amount of input data size. The resource.
Searching Topics Sequential Search Binary Search.
CISC220 Spring 2010 James Atlas Lecture 07: Big O Notation.
DS.A.1 Algorithm Analysis Chapter 2 Overview Definitions of Big-Oh and Other Notations Common Functions and Growth Rates Simple Model of Computation Worst.
1 Chapter 2 Algorithm Analysis All sections. 2 Complexity Analysis Measures efficiency (time and memory) of algorithms and programs –Can be used for the.
Program Performance 황승원 Fall 2010 CSE, POSTECH. Publishing Hwang’s Algorithm Hwang’s took only 0.1 sec for DATASET1 in her PC while Dijkstra’s took 0.2.
1 Chapter 2 Algorithm Analysis Reading: Chapter 2.
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.
CSE 3358 NOTE SET 2 Data Structures and Algorithms 1.
1 7.Algorithm Efficiency These factors vary from one machine/compiler (platform) to another  Count the number of times instructions are executed So, measure.
1 ADT Implementation: Recursion, Algorithm Analysis Chapter 10.
Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second Edition, © 2005 Pearson Education, Inc. All rights reserved Recursion,
Algorithm Analysis 1.
Chapter 2 Algorithm Analysis
Analysis of Algorithms
ADT Implementation: Recursion, Algorithm Analysis, and Standard Algorithms Chapter 10 Nyhoff, ADTs, Data Structures and Problem Solving with C++, Second.
Analysis of Algorithms
Algorithm Analysis CSE 2011 Winter September 2018.
Algorithm Analysis (not included in any exams!)
Building Java Programs
Algorithm Efficiency Chapter 10.
CS 201 Fundamental Structures of Computer Science
Programming and Data Structure
Analysis of Algorithms
DS.A.1 Algorithm Analysis Chapter 2 Overview
Programming and Data Structure
Sum this up for me Let’s write a method to calculate the sum from 1 to some n public static int sum1(int n) { int sum = 0; for (int i = 1; i
Algorithmic complexity
Analysis of Algorithms
Presentation transcript:

Algorithm Complexity Analysis: Big-O Notation (Chapter 10.4) Dr. Yingwu Zhu

Measure Algorithm Efficiency Space utilization: amount of memory required Time efficiency: amount of time required to accomplish the task As space is not a problem nowadays Time efficiency is more emphasized But, in embedded computers or sensor nodes, space efficiency is still important

These vary from one platform to another Time Efficiency Time efficiency depends on : size of input speed of machine quality of source code quality of compiler These vary from one platform to another So, we cannot express time efficiency meaningfully in real time units such as seconds!

Time Efficiency Time efficiency = the number of times instructions executed A measurement of efficiency of an algorithm Measure computing time T(n) as T(n) = number of times the instructions executed T(n): computing time of an algorithm for input of size n

Example: calculating a mean Task # times executed Initialize the sum to 0 1 Initialize index i to 0 1 While i < n do following n+1 a) Add x[i] to sum n b) Increment i by 1 n Return mean = sum/n 1 Total 3n + 4

T(n): Order of Magnitude As number of inputs increases T(n) = 3n + 4 grows at a rate proportional to n Thus T(n) has the "order of magnitude" n

T(n): Order of Magnitude T(n)on input of size n, If there is some constant C such that T(n) < Cf(n) for all sufficiently large values of n Then T(n) said to have order of magnitude f(n), Written as: T(n) = O(f(n)) Big-Oh notation

Big Oh Notation Another way of saying this: The complexity of the algorithm is O(f(n)). Example: For the Mean-Calculation Algorithm:

Mean-Calculation Algorithm [1] int sum = 0; [2] int i = 0; [3] While(i < n) { [4] sum += a[i]; [5] i++; } [6] return sum/n;

Big Oh Notation Example: For the Mean-Calculation Algorithm: T(n) is O(n) Note that constants and multiplicative factors are ignored. Simple function: f(n) = n

Measure T(n) Not only depends on the input size, but also depends on the arrangement of the input items Best case: not informative Average value of T: difficult to determine Worst case: is used to measure an algorithm’s performance

Get a Taste int search (int a[n], int x) { // pseudocode for search x for (int i=0; i<n; i++) if (a[i]==x) return i; return -1; } // assuming the elements in a[] are unique Complexity analysis T(n): can you figure it out ?  -- best case: ? -- average value: ? -- worst case: ?

Get a Taste Answer: How to get this? Best case: O(1) Average case: O(n) Worst case: O(n) How to get this?

Simple Selection Sorting Algorithm,p554 // Algorithm to sort x[0]…x[n-1] into ascending order 1. for (int i=0; i<n-1; i++) { /*On the ith pass, first find the smallest element in the sublist x[i],…,x[n-1]. */ int spos = i; int smallest = x[spos]; for (int j=i+1; j<n; j++) { if (x[j] < smallest) { spos = j; smallest = x[j]; } // end if } // end for x[spos] = x[i]; X[i] = smallest }// end for

What’s the worst case T(n)? T(n) = O(n2) How do we get that? Let’s try!

Simplifying the complexity analysis Non-trivial computation in the preceding example Simplifying the Big-O estimating Identify the statement executed most often and determine its execution count (statement 4) Ignore items with lower degree Only the highest power of n that affects Big-O estimate Big-O estimate gives an approximate measure of the computing time of an algorithm for large inputs

Simple Selection Sorting Algorithm,p554 // Algorithm to sort x[0]…x[n-1] into ascending order 1. for (int i=0; i<n-1; i++) { /*On the ith pass, first find the smallest element in the sublist x[i],…,x[n-1]. */ int spos = i; int smallest = x[spos]; for (int j=i+1; j<n; j++) { if (x[j] < smallest) { spos = j; smallest = x[j]; } // end if } // end for x[spos] = x[i]; X[i] = smallest }// end for

Exercise 1 for (int k=0; k < n; k++) for (int i = 0; i < n; i++) m[i][j] = a[i][j] + b[i][j];

Exercise 2 for (int k=0; k < n; k++) for (int i = k+1; i < n; i++) m[i][j] = a[i][j] + b[i][j];

Exercise 3 n = 0; sum = 0; cin >> x; while (x != -999) { n++; sum += x; } mean = sum / n;

Binary Search Algorithm int bin_search(int a[], int item) // a [0… n-1] bool found = false; int first = 0; int last = n-1; while (first <= last && !found) { int loc = (first + last) / 2; if (item < a[loc]) last = loc – 1; else if (item > a[loc]) first = loc + 1; else found = !found; } //end while } //end bin_search

Binary Search Algorithm See p556. Step 1: identify the statement executed most often Step 2: determine the execution count for that statement (the worst case!) T(n)= O(log2n) Better approach: how binary search is performed?

Big-Oh notation f(n) is usually simple: n, n2, n3, ... 2^n, 1, log2n n log2n log2log2n

How about recursive algorithms? double power(double x, unsigned n) { if (n==0) return 1.0; return x * power(x, n-1); }

How to compute Big-Oh? Recurrence relation: expresses the computing time for input of size n in terms of smaller-sized inputs How to solve recurrence relations? Using telescoping principle: repeatedly apply the relation until the anchor case is reached

Exercise 5 double fun(double x, unsigned n) { if (n==0) return 1.0; return x*fun(x, n/2); }

Exercise 6 for (int i = 0; i < n * n; ++i) { sum = sum/n; for (int j = 0; j < i; ++j) j >> cout; }

Exercise 7 for (int j = 4; j < n; ++j) { cin >> val; for (int i = 0; i < j; ++i) { b = b * val; for (int k = 0; k < n; ++k) c = b + c; }

Exercise 8 for (int i = 1; i<n-1; i++) { temp = a[i]; for (int j = i-1; j >= 0; j--) if (temp < a[j]) a[j+1] = a[j]; else break; a[j+1] = temp; }

Review of Lecture How to measure algorithm efficiency? How to compute time efficiency T(n)? Big-Oh notation For an algorithm, give the Big-Oh notation Simplified analysis Non-recursive Recursive: telescoping principle