Download presentation
Presentation is loading. Please wait.
Published byBethanie Elliott Modified over 9 years ago
1
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 1 © Leong Hon Wai, 2003-2008 Notice…. No tutorial this Friday (12-Feb) Special class on BASIC Algorithms oFRIDAY, 12-Feb 204pm, SR1 oEmail me if you plan to come.
2
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 2 © Leong Hon Wai, 2003-2008 Efficiency of Algorithms Readings: [SG] Ch. 3 Chapter Outline: oAttributes of Algorithms oMeasuring Efficiency of Algorithms oSimple Analysis of Algorithms oPolynomial vs Exponential Time Algorithms
3
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 3 © Leong Hon Wai, 2003-2008 Efficiency of Algorithms Readings: [SG] Ch. 3 Chapter Outline: oAttributes of Algorithms uWhat makes a Good Algorithm uKey Efficiency considerations oMeasuring Efficiency of Algorithms oSimple Analysis of Algorithms oPolynomial vs Exponential Time Algorithms
4
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 4 © Leong Hon Wai, 2003-2008 What are good algorithms? Desirable attributes in an algorithm oCorrectness oSimplicity (Ease of understanding) oElegance oEfficiency oEmbrace Multiple Levels of Abstraction oWell Documented, Multi-Platform
5
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 5 © Leong Hon Wai, 2003-2008 Attribute: Correctness, Simplicity Correctness oDoes the algorithm solve the problem it is designed for? oDoes the algorithm solve all instances of the problem correctly? Simplicity (Ease of understanding) oIs it easy to understand, oIs it clear, concise (not tricky) oIs it easy to alter the algorithm? oImportant for program maintenance
6
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 6 © Leong Hon Wai, 2003-2008 Attributes: Abstraction, Elegance Multiple Levels of Abstraction oDecomposes problem into sub-problems oEasier to understand at different levels of abstraction? oUsable as modules (libraries) by others Elegance oHow clever or sophisticated is the algorithm? oIs pleasing and satisfying to the designer.
7
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 7 © Leong Hon Wai, 2003-2008 Attributes: Efficiency, etc… Efficiency oThe amount of time the algorithm requires? oThe amount of space the algorithm requires? oThe most important attribute oEspecially for large-scale problems. Well documented, multi-platform oIs well-documented with sufficient details oNot OS-dependent, company-dependent, computer-dependent
8
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 8 © Leong Hon Wai, 2003-2008 Attributes: Key Considerations… However, they are often contradictory oSimple algorithms are often slow oEfficient algorithms tend to be complicated When designing algorithms, all computer scientists strive to achieve Simplicity, Elegance Efficiency plus If you really want to learn how, take an algorithms course.algorithms course
9
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 9 © Leong Hon Wai, 2003-2008 Efficiency of Algorithms Readings: [SG] Ch. 3 Chapter Outline: oAttributes of Algorithms oMeasuring Efficiency of Algorithms uOne Problem, Many algorithmic solutions uTime complexity, Space complexity u notation, order of growth of functions oSimple Analysis of Algorithms oPolynomial vs Exponential Time Algorithms
10
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 10 © Leong Hon Wai, 2003-2008 One Problem, Many algorithmic solutions Given an algorithmic problem, Many different algorithms to solve it Problem: Searching for a name in a list; Algorithms: Sequential search binary search interpolation search, etc Problem: Searching for a name in a list; Algorithms: Sequential search binary search interpolation search, etc Slow, Take linear time Fast, Take logarithmic time Not covered in UIT2201
11
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 11 © Leong Hon Wai, 2003-2008 Sequential Search: Idea Search for NAME among a list of n names Start at the beginning and compare NAME to each entry in the list until a match is found
12
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 12 © Leong Hon Wai, 2003-2008 Figure 3.1: Sequential Search Algorithm Sequential Search: Pseudo-Code Initialization block Iteration block; the key step where most of the work is done Post-Processing block
13
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 13 © Leong Hon Wai, 2003-2008 Recall: Algorithm Sequential Search Seq-Search(N, T, n, NAME); begin i 1; Found No; while (Found=No) and (i <= n) do if (NAME = N[i]) then Print T[i]; Found Yes; else i i + 1; endif endwhile if (Found=No) then Print NAME “is not found” endif end; Precondition: The variables n, NAME and the arrays N and T have been read into memory.
14
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 14 © Leong Hon Wai, 2003-2008 Analysis of Algorithm (introduction) Analysis of Algorithms Analyze an algorithm to predict its efficiency – namely, the resources (time and space) that an algorithm need during its execution. Time complexity T A (n) the time taken by an algorithm A on problems with input size n Space complexity S A (n) the space taken by an algorithm A on problems with input size n
15
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 15 © Leong Hon Wai, 2003-2008 Sequential Search: Analysis Comparison of the NAME against a name in the list N of names oCentral unit of work (dominant operation) oUsed for efficiency analysis For lists with n entries oBest case (best case is usually not important) uNAME is the first name in the list u1 comparison u (1) Roughly means a constant
16
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 16 © Leong Hon Wai, 2003-2008 Sequential Search: Analysis For lists with n entries oWorst case (usually the most important) uNAME is the last name in the list uNAME is not in the list un comparisons u(n)u(n) oAverage case (sometimes used) uRoughly n/2 comparisons u(n)u(n) Roughly means “proportional to n” Here ½n is also proportional to n. The constant c in cn is not important. Usually, we let c=1.
17
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 17 © Leong Hon Wai, 2003-2008 Sequential Search: Analysis Space efficiency oUses 2n memory storage for the input names and telephone numbers oA few more memory storage for variables (NAME, i, FOUND) oSpace is (n) oVery space efficient
18
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 18 © Leong Hon Wai, 2003-2008 Figure 3.4. Work = cn for Various Values of c Viewing the Rate of Growth of T(n) = cn
19
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 19 © Leong Hon Wai, 2003-2008 Order of Magnitude: Order n [Linear] All functions that have a linear “shape” are considered equivalent As n grows large, the order of magnitude dominates the running time ominimizing effect of coefficients oand lower-order terms Order of magnitude n oWritten as (n) [read as “theta-n”] oFunctions vary as a c x n, for some constant c oLinear time
20
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 20 © Leong Hon Wai, 2003-2008 [SideTrack: Why analyze only dominant operations] In the analysis above, oWe only analyze the dominant operation This sub-section gives why. oNamely, why we can take short-cuts It may help you better appreciate “analysis of algorithm” obut, if you have difficulties with this part, you can skip it, without affecting anything else.
21
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 21 © Leong Hon Wai, 2003-2008 Analysis of Algorithm To estimate running time of algorithm oWithout actually running the algorithm Method… oEstimate cost (work done) for each elementary operation oAnalyze the number of times each operation is executed during the algorithm oThen, sum up the total cost (work done) by the algorithm AIM: To conclude that we oOnly need to analyze the dominant operation
22
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 22 © Leong Hon Wai, 2003-2008 Suppose we assume the following estimated costs Analyzing Algorithm Sequential Search #times 1 1+1 n+1 n *1 *n n 1 cost 1 20 5 4+20 20 1 5 4 1 StatementCostStatementCost assignment20Print4 while, if5endwhile1 T(n) = (1+20+20) + (n+1)5 + n(5+20+1) + (4+20)+(5+4+1) = 31n + 80 = (n) [proportional to n] Seq-Search(N, T, n, NAME); begin i 1; Found No; while (Found=No) and (i <= n) do if (NAME = N[i]) then Print T[i]; Found Yes; else i i + 1; endwhile if (Found=No) then Print NAME “is not found” endif end;
23
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 23 © Leong Hon Wai, 2003-2008 Now, let’s assume a different set of estimated of costs Analyzing Algorithm Sequential Search #times 1 1+1 n+1 n *1+1 *n n 1 cost 0 10 15 20+10 10 0 15 20 0 StatementCostStatementCost assignment10Print20 while, if15endwhile0 T(n) = (10+10) + (n+1)15 + n(15+10) + (20+10)+(15+20) = 40n + 100 = (n) [also proportional to n] Seq-Search(N, T, n, NAME); begin i 1; Found No; while (Found=No) and (i <= n) do if (NAME = N[i]) then Print T[i]; Found Yes; else i i + 1; endwhile if (Found=No) then Print NAME “is not found” endif end;
24
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 24 © Leong Hon Wai, 2003-2008 From the two examples above… Actual total cost different for oThe different sets of estimated costs for basic ops But… Order of growth is the same ofor the different sets of estimated costs for basic ops oAll linear (but with different constants) So… to simplify analysis oAssign a constant cost (1) for basic operation oCan analyze only the dominant operation(s) uNamely, the operation that is done “most often” uCan also ignore “lower order” terms uSuch as operations that are done only once
25
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 25 © Leong Hon Wai, 2003-2008 Only dominant ops, (1) cost per basic op ( (1) means a constant) Simplified Analysis #times n n cost (1) (1) (1) (1) StatementCostStatementCost assignment (1)(1) Print (1)(1) while, if (1)(1) endwhile (1)(1) T(n) = 4n x (1) (counting only dominant ops) = (4n) = (n) [proportional to n] Seq-Search(N, T, n, NAME); begin i 1; Found No; while (Found=No) and (i <= n) do if (NAME = N[i]) then Print T[i]; Found Yes; else i i + 1; endwhile if (Found=No) then Print NAME “is not found” endif end;
26
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 26 © Leong Hon Wai, 2003-2008 Identifying the dominant operation #times n T(n) = n x (1) = (n) [proportional to n] Seq-Search(N, T, n, NAME); begin i 1; Found No; while (Found=No) and (i <= n) do if (NAME = N[i]) then Print T[i]; Found Yes; else i i + 1; endwhile if (Found=No) then Print NAME “is not found” endif end; cost (1) (1) (1) (1) Name comparison is a dominant operation
27
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 27 © Leong Hon Wai, 2003-2008 As the above examples show, oSufficient to analyze only dominant operation oIt gives the same running time in notations oBut, it is MUCH simpler. Conclusion: oSufficent to analyze only dominant operation END of SideTrack: and remember… oIf you have difficulties with this sub-section, you can skip it, without affecting anything else. [END SideTrack: Why analyze only dominant operations]
28
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 28 © Leong Hon Wai, 2003-2008 Readings: [SG] Ch. 3 Chapter Outline: oAttributes of Algorithms oMeasuring Efficiency of Algorithms oSimple Analysis of Algorithms uSelection Sort Algorithm uPattern Match Algorithm uBinary Search Algorithm oPolynomial vs Exponential Time Algorithms Efficiency of Algorithms
29
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 29 © Leong Hon Wai, 2003-2008 Analysis of Algorithms To analyze algorithms, oAnalyze dominant operations oUse -notations to simplify analysis oDetermine order of the running time Can apply this at high-level pseudo-codes oIf high-level primitive are used u Analyze running time of high-level primitive u expressed in notations umultiply by number of times it is called oSee example in analysis of Selection Sort and Pattern-Matching
30
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 30 © Leong Hon Wai, 2003-2008 Sorting: Problem and Algorithms Problem: Sorting oTake a list of n numbers and rearrange them in increasing order Algorithms: oSelection Sort (n 2 ) oInsertion Sort (n 2 ) oBubble Sort (n 2 ) oMerge Sort (n lg n) oQuicksort (n lg n)** ** average case Not covered in the course
31
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 31 © Leong Hon Wai, 2003-2008 Selection sort Idea behind the algorithm… oRepeatedly u find the largest number in unsorted section uSwap it to the end (the sorted section) oRe-uses the Find-Max algorithm sorted mj swap A:A: 1n A[m] is largest among A[1..j]
32
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 32 © Leong Hon Wai, 2003-2008 Selection Sort Algorithm (pseudo-code) Selection-Sort(A, n); begin j n; while (j > 1) do m Find-Max(A,j); swap(A[m],A[j]); j j - 1; endwhile end; sorted mj swap A:A: 1n A[m] is largest among A[1..j]
33
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 33 © Leong Hon Wai, 2003-2008 Example of selection sort mj 6 6 10 13 5 5 8 8 swap
34
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 34 © Leong Hon Wai, 2003-2008 Example of selection sort j 6 6 10 8 8 5 5 13 6 6 10 13 5 5 8 8
35
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 35 © Leong Hon Wai, 2003-2008 Example of selection sort mj 6 6 10 8 8 5 5 13 6 6 10 13 5 5 8 8 swap
36
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 36 © Leong Hon Wai, 2003-2008 Example of selection sort j 6 6 10 8 8 5 5 13 6 6 10 13 5 5 8 8 6 6 5 5 8 8 10 13
37
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 37 © Leong Hon Wai, 2003-2008 Example of selection sort j 6 6 10 8 8 5 5 13 6 6 10 13 5 5 8 8 6 6 5 5 8 8 10 13 m swap
38
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 38 © Leong Hon Wai, 2003-2008 Example of selection sort j 6 6 10 8 8 5 5 13 6 6 10 13 5 5 8 8 6 6 5 5 8 8 10 13 6 6 5 5 8 8 10 13
39
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 39 © Leong Hon Wai, 2003-2008 Example of selection sort j 6 6 10 8 8 5 5 13 6 6 10 13 5 5 8 8 6 6 5 5 8 8 10 13 m swap 6 6 5 5 8 8 10 13
40
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 40 © Leong Hon Wai, 2003-2008 Example of selection sort j 6 6 10 8 8 5 5 13 6 6 10 13 5 5 8 8 6 6 5 5 8 8 10 13 6 6 5 5 8 8 10 13 5 5 6 6 8 8 10 13 Done.
41
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 41 © Leong Hon Wai, 2003-2008 Figure 3.6: Selection Sort Algorithm Selection Sort Algorithm [SG] unsorted
42
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 42 © Leong Hon Wai, 2003-2008 What about the time complexity? j 6 6 10 8 8 5 5 13 6 6 10 13 5 5 8 8 6 6 5 5 8 8 10 13 6 6 5 5 8 8 10 13 5 5 6 6 8 8 10 13 Done. Dominant operation: comparisons 4 comparisons 3 comparisons 2 comparisons 1 comparisons
43
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 43 © Leong Hon Wai, 2003-2008 Analysis of Selection Sort When sorting n numbers, o(n-1) comparisons in iteration 1 (when j = n) o(n-2) comparisons in iteration 2 (when j = n-1) o(n-3) comparisons in iteration 3 (when j = n-2) o............... o2 comparisons in iteration (n-2) (when j = 3) o1 comparisons in iteration (n-1) (when j = 2) Total number of comparisons: oCost = (n-1) + (n-2) + … + 2 + 1 = n(n-1)/2 = (n 2 ) Find-Max for j numbers takes (j-1) comparisons
44
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 44 © Leong Hon Wai, 2003-2008 Selection Sort: Time complexity: T(n) = (n 2 ) Space complexity: S(n) = (n) Analysis of Selection Sort: Summary Time complexity: (n 2 ) oComparisons: n(n-1)/2 oExchanges: n (swapping largest into place) oOverall time compexity: (n 2 ) Space complexity: (n) o (n) – space for input sequence, plus a few variables.
45
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 45 © Leong Hon Wai, 2003-2008 Analysis of Pat-Match Algorithm oAcheives good division-of-labour Overview: To analyze, we do bottom-up analysis oFirst, analyze time complexity of Match(T,k,P,m) u Note: This takes much more than (1) operations u Express in notation (simplified). oThen analyze Pat-Match Pat-Match(T, n, P, m) Match(T, k, P, m) “high-level” view “high-level” primitive Our pattern matching alg. consists of two modules
46
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 46 © Leong Hon Wai, 2003-2008 First, analyze Match high-level primitive Align T[k..k+m–1] with P[1..m] (Here, k = 4) Match(T,k,P,m); begin i 1; MisMatch No; while (i <= m) and (MisMatch=No) do if (T[k+i-1] not equal to P[i]) then MisMatch=Yes else i i + 1 endif endwhile Match not(MisMatch); (* Opposite of *) end; ATA P 1 23 CATATCATA T 1 23456789 i Dominant Op is comparison. In worst case, m comparisons. So, (m)
47
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 47 © Leong Hon Wai, 2003-2008 Next, Analyze Pat-Match Algorithm Pat-Match(T,n,P,m); (* Finds all occurrences of P in T *) begin k 1; while (k <= n-m+1) do if Match(T,k,P,m) = Yes then Print “Match at pos ”, k; endif k k+1; endwhile end; Dominant Operation: high level op Match(T,k,P,m); Match is called (n+1–m) times, each call cost (m) times Total: ((n+1–m)m) = (nm)
48
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 48 © Leong Hon Wai, 2003-2008 Figure 3.10: Work = cn 2 for various values of c Viewing the Rate of Growth of T(n) = cn 2
49
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 49 © Leong Hon Wai, 2003-2008 All functions (with highest-order term) cn 2 ohave similar shape ohave same order of growth Quadratic algorithm -- (n 2 ) oan algorithm that does cn 2 work u for some constant c oorder of magnitude is n 2 o (n 2 ) (read, theta n-square) Order of Magnitude – Order n 2 [Quadratic]
50
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 50 © Leong Hon Wai, 2003-2008 Comparison: Order n vs Order n 2 Have seen… Algorithms of order n oSum, Find-Max, Find-Min, Seq-Search Algorithm of order n 2 oSelection sort oPrinting an n x n table
51
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 51 © Leong Hon Wai, 2003-2008 Figure 3.11: A Comparison of n and n 2 Rate of Growth Comparison: n 2 vs n
52
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 52 © Leong Hon Wai, 2003-2008 Anything that is (n 2 ) will eventually have larger values than anything that is (n), no matter what the constants are. An algorithm that runs in time (n) will outperform one that runs in (n 2 ) Eg: compare T 1 (n) = 1000n and T 2 (n) = 10n 2 Comparison: (n 2 ) vs (n) See also tutorial problem.
53
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 53 © Leong Hon Wai, 2003-2008 A Very Fast Search Algorithm If the list is sorted, that is A 1 A 2 A 3 …. A n Then, we can do better when searching o actually a lot better…. Can use “Binary Search” Example: Find 9 357891215
54
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 54 © Leong Hon Wai, 2003-2008 Binary search Find an element in a sorted array: IDEA: Check middle element. Recursively search 1 subarray. Example: Find 9 357891215
55
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 55 © Leong Hon Wai, 2003-2008 Binary search Find an element in a sorted array: IDEA: Check middle element. Recursively search 1 subarray. Example: Find 9 357891215
56
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 56 © Leong Hon Wai, 2003-2008 Binary search Find an element in a sorted array: IDEA: Check middle element. Recursively search 1 subarray. Example: Find 9 357891215
57
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 57 © Leong Hon Wai, 2003-2008 Binary search Find an element in a sorted array: IDEA: Check middle element. Recursively search 1 subarray. Example: Find 9 357891215
58
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 58 © Leong Hon Wai, 2003-2008 Binary search Find an element in a sorted array: IDEA: Check middle element. Recursively search 1 subarray. Example: Find 9 357891215
59
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 59 © Leong Hon Wai, 2003-2008 Binary search Find an element in a sorted array: IDEA: Check middle element. Recursively search 1 subarray. Example: Find 9 357891215 Found!
60
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 60 © Leong Hon Wai, 2003-2008 Binary search – overview of algorithm Find an element in a sorted array: 1. Check middle element. Have two pointers first, last on two ends of the sub-array being search Here, mid = (first + last) / 2; Move one of the two pointers to update the sub-array being search. Either last mid – 1; Or first mid + 1; 2. Recursively search 1 subarray.
61
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 61 © Leong Hon Wai, 2003-2008 Binary Search Algorithm (pseudo-code) BinarySearch(A,n,x); (* search for x in a sorted array A[1..n] *) begin first 1; last n; while (first <= last) do mid (first + last) div 2; if (x = A[mid]) then print “Found x in pos”, mid; Stop else if (x < A[mid]) then last mid-1; else first mid+1; endif endwhile print “x not found”; end;
62
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 62 © Leong Hon Wai, 2003-2008 Binary Search – How fast is it? (1/3) Starting with n numbers, oBinary search repeatedly halves the size oUntil it reaches 1 element – to check Eg: When n = 100 oAfter 1 step, size is 50 oAfter 2 steps, size is 25 oAfter 3 steps, size is 12 oAfter 4 steps, size is 6 oAfter 5 steps, size is 3 oAfter 6 steps, size is 1 oOne last comparison, DONE!! 7 = log 2 100 steps; [Déjà vu? repeated-halving]
63
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 63 © Leong Hon Wai, 2003-2008 Starting with n numbers, oBinary search repeatedly halves the size oUntil it reaches 1 element – to check # steps = lg n = log 2 n Binary Search has complexity oT(n) = ( lg n) Recall facts about T(n) = lg n When 2 k = n [after taking lg-base-2] k = log 2 n or lg n = # of steps of repeated-halving Binary Search – How fast is it? (2/3)
64
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 64 © Leong Hon Wai, 2003-2008 Starting with n numbers, oBinary search repeatedly halves the size oUntil it reaches 1 element – to check # steps = lg n = log 2 n Binary Search has complexity oT(n) = ( lg n) T(n) = (lg n) is very fast! n (# of element) T(n) = lg n 1,000 10 1,000,000 20 1,000,000,000 30 Binary Search – How fast is it? (3/3)
65
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 65 © Leong Hon Wai, 2003-2008 Summary: Searching Algorithms Sequential Search (Alg): o Worst Case: n comparisons o Best Case: 1 comparison o Avg Case: n/2 comparisons Binary Search (Alg): oWorst Case: lg n comparisons o Best Case: 1 comparison o Avg Case: lg n comparisons* * How to get the Average Case ? Answer: using mathematical analysis. This is OK (do-able) for small n (see example in tutorial). (Read Sect 3.4.2 of [SG3]) For general n, analysis is complex (beyond the scope of this course)
66
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 66 © Leong Hon Wai, 2003-2008 Figure 3.21. A Comparison of n and lg n Comparison: order n vs order lg n
67
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 67 © Leong Hon Wai, 2003-2008 Complexity of Algorithms… Logarithmic Time Algorithm oBinary Search – (lg n) time A Linear Time Algorithm oSum(A,n) – (n) time oSequential-Search(A,n,x) – (n) time A Quadratic Time Algorithm oSelection Sort – (n 2 ) time An Exponential Time Algorithm oAll-Subsets(A,n) – (2 n ) time
68
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 68 © Leong Hon Wai, 2003-2008 Figure 3.22: Summary of Time Efficiency Complexity of Time Efficiency
69
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 69 © Leong Hon Wai, 2003-2008 Readings: [SG] Ch. 3 Chapter Outline: oAttributes of Algorithms oMeasuring Efficiency of Algorithms oSimple Analysis of Algorithms oWhen things get out of hand uPolynomial Time Algorithms (Tractable) uExponential Time Algorithms (Intractable) uApproximation Algorithms (eg: Bin Packing) Efficiency of Algorithms
70
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 70 © Leong Hon Wai, 2003-2008 When Things Get Out of Hand Polynomially bound algorithms oTime complexity is some polynomial order oExample: Time complexity is of order of n 2 Intractable algorithms oRun time is worse than polynomial time oExamples uHamiltonian circuit uBin-packing
71
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 71 © Leong Hon Wai, 2003-2008 Figure 3.27: A Comparison of Four Orders of Magnitude Comparison of Time Complexities See extended table in tutorial problem
72
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 72 © Leong Hon Wai, 2003-2008 Figure 3.25: Comparisons of lg n, n, n 2, and 2 n
73
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 73 © Leong Hon Wai, 2003-2008 When Things Get Out of Hand (2) Exponential algorithm o (2 n ) oMore work than any polynomial in n Approximation algorithms oRun in polynomial time but do not give optimal solutions oExample: Bin Packing Algorithms
74
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 74 © Leong Hon Wai, 2003-2008 Summary of Chapter 3 Desirable attributes in algorithms: oCorrectness oEase of understanding oElegance oEfficiency Efficiency of an algorithm is extremely important oTime Complexity oSpace Complexity
75
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 75 © Leong Hon Wai, 2003-2008 Summary of Chapter 3 (2) To compare the efficiency of two algorithms that do the same task oMeasure their time complexities Efficiency focuses on order of magnitude oTime complexity in -notations. oIn its simplest form (eg: (n), (n 2 ))
76
LeongHW, SoC, NUS (UIT2201: Algorithms) Page 76 © Leong Hon Wai, 2003-2008 Thank you!
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.