48
Data Structures Basic Terminologies & Asymptotic Notations 1

Basic terminologies & asymptotic notations

Embed Size (px)

Citation preview

Page 1: Basic terminologies & asymptotic notations

Data Structures

Basic Terminologies & Asymptotic Notations

1

Page 2: Basic terminologies & asymptotic notations

Data Structures

“Clever” ways to organize information in order to enable efficient computation

– What do we mean by clever?– What do we mean by efficient?

2Basic Terminologies & Asymptotic Notations

Page 3: Basic terminologies & asymptotic notations

Picking the best Data Structure for the job

• The data structure you pick needs to support the operations you need

• Ideally it supports the operations you will use most often in an efficient manner

• Examples of operations:– A List with operations insert and delete– A Stack with operations push and pop

3Basic Terminologies & Asymptotic Notations

Page 4: Basic terminologies & asymptotic notations

Terminology• Abstract Data Type (ADT)

– Mathematical description of an object with set of operations on the object. Useful building block.

• Algorithm– A high level, language independent,

description of a step-by-step process• Data structure

– A specific family of algorithms for implementing an abstract data type.

• Implementation of data structure– A specific implementation in a specific

language

4Basic Terminologies & Asymptotic Notations

Page 5: Basic terminologies & asymptotic notations

Terminology

• DataData refers to value or set of values.

e.g.Marks obtained by the students.

• Data typedata type is a classification identifying one of various types of data, such as floating-point, integer, or Boolean, that determines the possible values for that type; the

operations that can be done on values of that type; and the way

values of that type can be stored

Data Structures - Introduction 5

Page 6: Basic terminologies & asymptotic notations

Terminology• Primitive data type:These are basic data types that are provided by theprogramming language with built-in support. These datatypes are native to the language. This data type issupported by machine directly

• VariableVariable is a symbolic name given to some known or unknown quantity or information, for the purpose of allowing the name to be used independently of the information it represents.

Data Structures - Introduction 6

Page 7: Basic terminologies & asymptotic notations

Terminology

• RecordCollection of related data items is known as record. The elements of records are usually Called fields or members .Records are distinguished from arrays by the fact that their number of fields is typically fixed, each field has a name, and that each field may have a different type.

• ProgramA sequence of instructions that a computer can interpret and execute.

Data Structures - Introduction 7

Page 8: Basic terminologies & asymptotic notations

Terminology examples

• A stack is an abstract data type supporting push, pop and isEmpty operations

• A stack data structure could use an array, a linked list, or anything that can hold data

• One stack implementation is java.util.Stack; another is java.util.LinkedList

8Basic Terminologies & Asymptotic Notations

Page 9: Basic terminologies & asymptotic notations

Concepts vs. Mechanisms

• Abstract• Pseudocode• Algorithm

– A sequence of high-level, language independent operations, which may act upon an abstracted view of data.

• Abstract Data Type (ADT)– A mathematical

description of an object and the set of operations on the object.

• Concrete• Specific programming language• Program

– A sequence of operations in a specific programming language, which may act upon real data in the form of numbers, images, sound, etc.

• Data structure– A specific way in which a

program’s data is represented, which reflects the programmer’s design choices/goals. 9

Page 10: Basic terminologies & asymptotic notations

Why So Many Data Structures?

Ideal data structure:“fast”, “elegant”, memory efficient

Generates tensions:– time vs. space– performance vs. elegance– generality vs. simplicity– one operation’s performance vs.

another’s The study of data structures is the study of tradeoffs. That’s why we have so many of them!

10Basic Terminologies & Asymptotic Notations

Page 11: Basic terminologies & asymptotic notations

Data Structures

Asymptotic Analysis

11Basic Terminologies & Asymptotic Notations

Page 12: Basic terminologies & asymptotic notations

Algorithm Analysis: Why?

• Correctness:– Does the algorithm do what is intended.

• Performance:– What is the running time of the algorithm.– How much storage does it consume.

• Different algorithms may be correct– Which should I use?

12Basic Terminologies & Asymptotic Notations

Page 13: Basic terminologies & asymptotic notations

Recursive algorithm for sum

• Write a recursive function to find the sum of the first n integers stored in array v.

13

Page 14: Basic terminologies & asymptotic notations

Proof by Induction

• Basis Step: The algorithm is correct for a base case or two by inspection.

• Inductive Hypothesis (n=k): Assume that the algorithm works correctly for the first k cases.

• Inductive Step (n=k+1): Given the hypothesis above, show that the k+1 case will be calculated correctly.

14

Page 15: Basic terminologies & asymptotic notations

Program Correctness by Induction

• Basis Step:sum(v,0) = 0.

• Inductive Hypothesis (n=k): Assume sum(v,k) correctly returns sum of first k elements of v, i.e. v[0]+v[1]+…+v[k-1]+v[k]

• Inductive Step (n=k+1): sum(v,n) returnsv[k]+sum(v,k-1)= (by inductive hyp.)v[k]+(v[0]+v[1]+…+v[k-1])=v[0]+v[1]+…+v[k-1]+v[k]

15

Page 16: Basic terminologies & asymptotic notations

Algorithms vs Programs

• Proving correctness of an algorithm is very important– a well designed algorithm is guaranteed to

work correctly and its performance can be estimated

• Proving correctness of a program (an implementation) is fraught with weird bugs– Abstract Data Types are a way to bridge the

gap between mathematical algorithms and programs

16

Page 17: Basic terminologies & asymptotic notations

Comparing Two Algorithms

GOAL: Sort a list of names

“I’ll buy a faster CPU”

“I’ll use C++ instead of Java – wicked fast!”

“Ooh look, the –O4 flag!”

“Who cares how I do it, I’ll add more memory!”

“Can’t I just get the data pre-sorted??”17

Page 18: Basic terminologies & asymptotic notations

Comparing Two Algorithms

• What we want:– Rough Estimate– Ignores Details

• Really, independent of details – Coding tricks, CPU speed, compiler

optimizations, …– These would help any algorithms equally– Don’t just care about running time – not a

good enough measure18

Page 19: Basic terminologies & asymptotic notations

Big-O Analysis

• Ignores “details”• What details?

– CPU speed– Programming language used– Amount of memory– Compiler– Order of input– Size of input … sorta.

19

Page 20: Basic terminologies & asymptotic notations

Analysis of Algorithms

• Efficiency measure– how long the program runs time complexity– how much memory it uses space complexity

• Why analyze at all?– Decide what algorithm to implement before

actually doing it– Given code, get a sense for where

bottlenecks must be, without actually measuring it

20

Page 21: Basic terminologies & asymptotic notations

Asymptotic Analysis

• Complexity as a function of input size nT(n) = 4n + 5T(n) = 0.5 n log n - 2n + 7T(n) = 2n + n3 + 3n

• What happens as n grows?

21

Page 22: Basic terminologies & asymptotic notations

Why Asymptotic Analysis?

• Most algorithms are fast for small n – Time difference too small to be noticeable– External things dominate (OS, disk I/O, …)

• BUT n is often large in practice– Databases, internet, graphics, …

• Difference really shows up as n grows!

22

Page 23: Basic terminologies & asymptotic notations

Exercise - Searching

bool ArrayFind( int array[], int n, int key){// Insert your algorithm here

}

2 3 5 16 37 50 73 75 126

What algorithm would you choose to

implement this code snippet?23

Page 24: Basic terminologies & asymptotic notations

Analyzing Code

Basic Java operations

Consecutive statements

ConditionalsLoops

Function callsRecursive functions

Constant timeSum of timesLarger branch plus

testSum of iterationsCost of function bodySolve recurrence

relation

24

Page 25: Basic terminologies & asymptotic notations

Linear Search Analysis

bool LinearArrayFind(int array[],int n, int key ) {

for( int i = 0; i < n; i++ ) {if( array[i] == key )

// Found it!return true;

}return false;

}

Best Case:

Worst Case:

25

Page 26: Basic terminologies & asymptotic notations

Binary Search Analysisbool BinArrayFind( int array[], int low,

int high, int key ) {// The subarray is emptyif( low > high ) return false;

// Search this subarray recursivelyint mid = (high + low) / 2;if( key == array[mid] ) {

return true;} else if( key < array[mid] ) {

return BinArrayFind( array, low, mid-1, key );

} else {return BinArrayFind( array, mid+1,

high, key );}

Best case:

Worst case:

26

Page 27: Basic terminologies & asymptotic notations

Solving Recurrence Relations

1. Determine the recurrence relation. What is/are the base case(s)?

2. “Expand” the original relation to find an equivalent general expression in terms of the number of expansions.

3. Find a closed-form expression by setting the number of expansions to a value which reduces the problem to a base case 27

Page 28: Basic terminologies & asymptotic notations

Data Structures

Asymptotic Analysis

28

Page 29: Basic terminologies & asymptotic notations

Linear Search vs Binary Search

Linear Search Binary Search

Best Case 4 at [0] 4 at [middle]

Worst Case 3n+2 4 log n + 4

So … which algorithm is better?What tradeoffs can you make?

29

Page 30: Basic terminologies & asymptotic notations

Fast Computer vs. Slow Computer

30

Page 31: Basic terminologies & asymptotic notations

Fast Computer vs. Smart Programmer (round 1)

31

Page 32: Basic terminologies & asymptotic notations

Fast Computer vs. Smart Programmer (round 2)

32

Page 33: Basic terminologies & asymptotic notations

Asymptotic Analysis• Asymptotic analysis looks at the order of the

running time of the algorithm– A valuable tool when the input gets “large”– Ignores the effects of different machines or

different implementations of an algorithm

• Intuitively, to find the asymptotic runtime, throw away the constants and low-order terms– Linear search is T(n) = 3n + 2 O(n)– Binary search is T(n) = 4 log2n + 4 O(log n)

Remember: the fastest algorithm has the slowest growing function

for its runtime33Basic Terminologies & Asymptotic Notations

Page 34: Basic terminologies & asymptotic notations

Asymptotic Analysis

• Eliminate low order terms– 4n + 5 – 0.5 n log n + 2n + 7 – n3 + 2n + 3n

• Eliminate coefficients– 4n – 0.5 n log n – n log n2 =>

34Basic Terminologies & Asymptotic Notations

Page 35: Basic terminologies & asymptotic notations

Properties of Logs

• log AB = log A + log B• Proof:

• Similarly:– log(A/B) = log A – log B– log(AB) = B log A

• Any log is equivalent to log-base-2

BAAB

AB

BABABA

BA

logloglog

222

2,2)log(logloglog

loglog

2222

22

35Basic Terminologies & Asymptotic Notations

Page 36: Basic terminologies & asymptotic notations

Order Notation: Intuition

Although not yet apparent, as n gets “sufficiently large”, f(n) will be “greater than or equal to” g(n)

f(n) = n3 + 2n2

g(n) = 100n2 + 1000

36Basic Terminologies & Asymptotic Notations

Page 37: Basic terminologies & asymptotic notations

Definition of Order Notation

• Upper bound: T(n) = O(f(n)) Big-OExist positive constants c and n’ such that

T(n) c f(n) for all n n’

• Lower bound: T(n) = (g(n)) OmegaExist positive constants c and n’ such that

T(n) c g(n) for all n n’

• Tight bound: T(n) = (f(n)) ThetaWhen both hold:

T(n) = O(f(n))T(n) = (f(n))

37Basic Terminologies & Asymptotic Notations

Page 38: Basic terminologies & asymptotic notations

Definition of Order Notation

O( f(n) ) : a set or class of functions

g(n) O( f(n) ) iff there exist positive consts c and n0 such that:

g(n) c f(n) for all n n0

Example:100n2 + 1000 5 (n3 + 2n2) for all n 19

So g(n) O( f(n) )38Basic Terminologies & Asymptotic

Notations

Page 39: Basic terminologies & asymptotic notations

Order Notation: Example

100n2 + 1000 5 (n3 + 2n2) for all n 19So f(n) O( g(n) )

39Basic Terminologies & Asymptotic Notations

Page 40: Basic terminologies & asymptotic notations

Some Notes on Notation

• Sometimes you’ll seeg(n) = O( f(n) )

• This is equivalent tog(n) O( f(n) )

• What about the reverse?O( f(n) ) = g(n)

40Basic Terminologies & Asymptotic Notations

Page 41: Basic terminologies & asymptotic notations

Big-O: Common Names

– constant: O(1)

– logarithmic: O(log n) (logkn, log n2 O(log n))

– linear: O(n)– log-linear: O(n log n)– quadratic: O(n2)– cubic: O(n3)– polynomial: O(nk) (k is a constant)– exponential: O(cn) (c is a constant > 1)

41Basic Terminologies & Asymptotic Notations

Page 42: Basic terminologies & asymptotic notations

Meet the Family

• O( f(n) ) is the set of all functions asymptotically less than or equal to f(n)– o( f(n) ) is the set of all functions

asymptotically strictly less than f(n)

• ( f(n) ) is the set of all functions asymptotically greater than or equal to f(n)– ( f(n) ) is the set of all functions

asymptotically strictly greater than f(n)

• ( f(n) ) is the set of all functions asymptotically equal to f(n)

42Basic Terminologies & Asymptotic Notations

Page 43: Basic terminologies & asymptotic notations

Meet the Family, Formally• g(n) O( f(n) ) iff

There exist c and n0 such that g(n) c f(n) for all n n0

– g(n) o( f(n) ) iff There exists a n0 such that g(n) < c f(n) for all c and n n0

• g(n) ( f(n) ) iffThere exist c and n0 such that g(n) c f(n) for all n n0

– g(n) ( f(n) ) iffThere exists a n0 such that g(n) > c f(n) for all c and n n0

• g(n) ( f(n) ) iffg(n) O( f(n) ) and g(n) ( f(n) )

Equivalent to: limn g(n)/f(n) = 0

Equivalent to: limn g(n)/f(n) =

43Data Structures - Introduction

Page 44: Basic terminologies & asymptotic notations

Big-Omega et al. Intuitively

Asymptotic Notation

Mathematics Relation

O =

o <

>

44Basic Terminologies & Asymptotic Notations

Page 45: Basic terminologies & asymptotic notations

Pros and Cons of Asymptotic Analysis

45Basic Terminologies & Asymptotic Notations

Page 46: Basic terminologies & asymptotic notations

Perspective: Kinds of Analysis

• Running time may depend on actual data input, not just length of input

• Distinguish– Worst Case

• Your worst enemy is choosing input– Best Case– Average Case

• Assumes some probabilistic distribution of inputs

– Amortized• Average time over many operations

46Basic Terminologies & Asymptotic Notations

Page 47: Basic terminologies & asymptotic notations

Types of AnalysisTwo orthogonal axes:

– Bound Flavor• Upper bound (O, o)• Lower bound (, )• Asymptotically tight ()

– Analysis Case• Worst Case (Adversary)• Average Case• Best Case• Amortized

47Basic Terminologies & Asymptotic Notations

Page 48: Basic terminologies & asymptotic notations

16n3log8(10n2) + 100n2 = O(n3log n)

• Eliminate low-order terms

• Eliminate constant coefficients

16n3log8(10n2) + 100n2

16n3log8(10n2)

n3log8(10n2)

n3(log8(10) + log8(n2))

n3log8(10) + n3log8(n2)

n3log8(n2)

2n3log8(n)

n3log8(n)

n3log8(2)log(n)n3log(n)/3n3log(n)

48Basic Terminologies & Asymptotic Notations