Section 2.2 of Rosen: Cse235@cse - Unl.edu
Section 2.2 of Rosen: Cse235@cse - Unl.edu
Section 2.2 of Rosen: Cse235@cse - Unl.edu
Slides by Christopher M. Bourke Instructor: Berthe Y. Choueiry Recall that we are really only interested in the Order of Growth of an algorithms complexity. How well does the algorithm perform as the input size grows; n Spring 2006 We have seen how to mathematically evaluate the cost functions of algorithms with respect to their input size n and their elementary operation. However, it suces to simply measure a cost functions asymptotic behavior.
Introduction
Magnitude Graph
Introduction I
f (n) 20 15 10 5 n 0 5 10 15 20
f (n) = log (n) f (n) = x f (n) = n log (n) f (n) = n2 f (n) = n3 f (n) = 2n f (n) = n!
In practice, specic hardware, implementation, languages, etc. will greatly aect how the algorithm behaves. However, we want to study and analyze algorithms in and of themselves, independent of such factors. For example, an algorithm that executes its elementary operation 10n times is better than one which executes it .005n2 times. Moreover, algorithms that have running times n2 and 2000n2 are considered to be asymptotically equivalent.
Big-O Denition
Denition
Let f and g be two functions f, g : N R+ . We say that f (n) O(g(n)) (read: f is Big-O of g) if there exists a constant c R+ and n0 N such that for every integer n n0 , f (n) cg(n)
Big-Omega Denition
Denition
Let f and g be two functions f, g : N R+ . We say that f (n) (g(n)) (read: f is Big-Omega of g) if there exist c R+ and n0 N such that for every integer n n0 , f (n) cg(n)
Big-O is actually Omicron, but it suces to write O Intuition: f is (asymptotically) less than or equal to g Big-O gives an asymptotic upper bound
Intuition: f is (asymptotically) greater than or equal to g. Big-Omega gives an asymptotic lower bound.
Big-Theta Denition
Denition
Let f and g be two functions f, g : N R+ . We say that f (n) (g(n)) (read: f is Big-Theta of g) if there exist constants c1 , c2 R+ and n0 N such that for every integer n n0 , c1 g(n) f (n) c2 g(n)
Asymptotic Properties I
Theorem
For f1 (n) O(g1 (n)) and f2 O(g2 (n)), f1 (n) + f2 (n) O(max{g1 (n), g2 (n)})
This property implies that we can ignore lower order terms. In particular, for any polynomial p(n) with degree k, p(n) O(nk ).1 In addition, this gives us justication for ignoring constant coecients. That is, for any function f (n) and positive constant c,
Intuition: f is (asymptotically) equal to g. f is bounded above and below by g. Big-Theta gives an asymptotic equivalence. cf (n) (f (n))
Asymptotic Properties II
Corollary
For positive functions, f (n) and g(n) the following hold: f (n) (g(n)) f (n) O(g(n)) and f (n) (g(n)) f (n) O(g(n)) g(n) (f (n)) The proof is left as an exercise.
Proving an asymptotic relationship between two given functions f (n) and g(n) can be done intuitively for most of the functions you will encounter; all polynomials for example. However, this does not suce as a formal proof. To prove a relationship of the form f (n) (g(n)) where is one of O, , or , can be done simply using the denitions, that is: nd a value for c (or c1 and c2 ). nd a value for n0 . (But this is not the only way.)
Example
Let f (n) = 21n2 + n and g(n) = n3 . Our intuition should tell us that f (n) O(g(n)). Simply using the denition conrms this: 21n2 + n cn3 holds for, say c = 3 and for all n n0 = 8 (in fact, an innite number of pairs can satisfy this equation).
Example
Let f (n) = n2 + n and g(n) = n3 . Find a tight bound of the form f (n) (g(n)). Our intuition tells us that f (n) O(n3 )
Proof. Example
If n 1 it is clear that n n3 and n2 n3 . Therefore, we have that n2 + n n3 + n3 = 2n3 Here, our intuition should tell us that Thus, for n0 = 1 and c = 2, by the denition of Big-O, we have that f (n) O(g(n)). f (n) (g(n)) Let f (n) = n3 + 4n2 and g(n) = n2 . Find a tight bound of the form f (n) (g(n)).
Proof.
If n 0 then n3 n3 + 4n2 As before, if n 1, n2 n3 Thus, when n 1, n2 n3 n3 + 3n2 Thus by the denition of Big-, for n0 = 1, c = 1, we have that f (n) (g(n)). If you have a polynomial of degree 2 such as an2 + bn + c, you can prove it is (n2 ) using the following values: c1 = c2 =
a 4 7a 4 |c| a)
n0 = 2 max( |b| , a
Limit Method
Now try this one: f (n) = n50 + 12n3 log4 n 1243n12 + 245n6 log n + 12 log3 n log n g(n) = 12n50 + 24 log14 n4 3 log5n + 12 n Using the formal denitions can be very tedious especially when one has very complex functions. It is much better to use the Limit Method which uses concepts from calculus.
lHpitals Rule o
lHpitals Rule I o
Justication
Theorem
(lHpitals Rule) Let f and g, if the limit between the quotient o f (n) g(n) exists, it is equal to the limit of the derivative of the denominator and the numerator.
n
Why do we have to use lHpitals Rule? Consider the following o function: sin x x
f (x) =
lim
Clearly, sin 0 = 0 so you may say that f (x) = 0. However, the denominator is also zero so you may say f (x) = , but both are wrong.
lHpitals Rule II o
Justication
Clearly, though f (x) is undened at x = 0, the limit still exists. Applying lHpitals Rule gives us the correct answer: o lim sin x cos x = =1 x 1
x0
Figure: f (x) =
sin x x
Limit Method
Example 1
Limit Method
Example 1 - Proof A
Proof.
We prove using limits. We set up our limit,
Example
Let f (n) = 2n , g(n) = 3n . Determine a tight inclusion of the form f (n) (g(n)). Whats our intuition in this case?
n
lim
f (n) 2n = n g(n) 3
Using lHpitals Rule will get you no where: o 2n (ln 2)2n = 3n (ln 3)3n Both numerator and denominator still diverge. Well have to use an algebraic simplication.
Limit Method
Example 1 - Proof B
Limit Method
Example 2
Continued.
Using algebra, 2n = n 3n lim 2 3
n
Example
Let f (n) = log2 n, g(n) = log3 n2 . Determine a tight inclusion of the form f (n) (g(n)). Whats our intuition in this case?
Now we use the following Theorem without proof: if < 1 0 1 if = 1 lim = n if > 1 Therefore we conclude that the quotient converges to zero thus, 2n O(3n )
Limit Method
Example 2 - Proof A
Limit Method
Example 2 - Proof B
Proof.
We prove using limits. We set up our limit, lim f (n) log2 n = g(n) log3 n2
Continued.
And we get that lim f (n) g(n) = = = log2 (n) log3 (n2 ) log2 n
2 log2 n log2 3
Here, we have to use the change of base formula for logarithms: log n log n = log
Limit Properties
Some useful derivatives that you should memorize include A useful property of limits is that the composition of functions is preserved. (nk ) = knk1 (logb (n)) =
1 n ln (b)
Lemma
For the composition of addition, subtraction, multiplication and division, if the limits exist (that is, they converge), then
n
(f1 (n)f2 (n)) = f1 (n)f2 (n) + f1 (n)f2 (n) (product rule) (cn ) = ln (c)cn Careful! Log Identities Change of Base Formula: logb (n) = log (nk ) = k log (n) log (ab) = log (a) + log (b)
logc (n) logc (b)
Eciency Classes
Summary
O(1) O(log (n)) O(n) O(logk (n)) O(n2 ) O(n3 ) O(nk ) for any k > 0 O(2n ) O(2f (n) ) for f (n) = n(1+ ) , > 0 For example, n!
Asymptotics is easy, but remember: Always look for algebraic simplications You must always give a rigorous proof Using the limit method is always the best Always show lHpitals Rule if need be o Give as simple (and tight) expressions as possible