1 / 29

Algorithms

Algorithms. Problems, Algorithms, Programs. Problem - a well defined task. Sort a list of numbers. Find a particular item in a list. Find a winning chess move. Algorithms. A series of precise steps, known to stop eventually, that solve a problem. NOT necessarily tied to computers.

gavin
Download Presentation

Algorithms

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Algorithms

  2. Problems, Algorithms, Programs • Problem - a well defined task. • Sort a list of numbers. • Find a particular item in a list. • Find a winning chess move.

  3. Algorithms • A series of precise steps, known to stop eventually, that solve a problem. • NOT necessarily tied to computers. • There can be many algorithms to solve the same problem.

  4. Characteristics of an Algorithm • Precise steps. • Effective steps. • Has an output. • Terminates eventually.

  5. Trivial Algorithm • Computing an average: • Sum up all of the values. • Divide the sum by the number of values.

  6. Problem - Finding the Greatest Common Denominator • Examples: • gcd(12, 2) = 2 • gcd(100, 95) = 5 • gcd(100, 75) = 25 • gcd(39, 26) = 13 • gcd(17, 8) = 1

  7. Possible Algorithm #1 • Assumption: A > B >= 0 • If A is a multiple of B, then gcd(A, B) = B. • Otherwise, return an error. • Works for gcd(12,2) = 2 • But what about gcd(100, 95)???

  8. Possible Algorithm #2 • Start with 1 and go up to B. • If a number if a common divisor of both A and B, remember it. • When we get to B, stop. The last number we remembered is the gcd. • Works, but is there a better way? • Think about gcd(100, 95)

  9. Euclid’s Algorithm • Make use of the fact that: • gcd(A, B) = gcd(B, A rem B) • Note: A rem B refers to the remainder left when A is divided by B. • Examples: • 12 rem 2 = 0 • 100 rem 95 = 5

  10. Euclid’s Algorithm If B = 0, then gcd(A, B) = A. Otherwise, gcd(A, B) = gcd (B, A rem B). • Note – this algorithm is recursive. • Examples: • gcd(12, 2) = gcd(2, 0) = 2 • gcd(100, 95) = gcd(95, 5) = gcd(5, 0) = 5

  11. Why do we care? • Let’s say we want the gcd of 1,120,020,043,575,432 and 1,111,363,822,624,856 • Assume we can do 100,000,000 divisions per second. • Algorithm #2 will take about three years. • Euclid’s Algorithm will take less than a second.

  12. Programs vs. Algorithms • Program: “A set of computer instructions written in a programming language” • We write Programs that implement Algorithms

  13. Algorithm vs. Program • If B = 0, then gcd(A, B) = A. • Otherwise, gcd(A, B) = gcd (B, A rem B). def gcd(A, B): if B == 0: return A else: return gcd(B, A % B)

  14. Problems vs. Algorithms vs. Programs • There can be many algorithms that solve the same problem. • There can be many programs that implement the same algorithm. • We are concerned with: • Analyzing the difficulty of problems. • Finding good algorithms. • Analyzing the efficiency of algorithms.

  15. Classifying Problems • Problems fall into two categories. • Computable problems can be solved using an algorithm. • Non-computable problems have no algorithm to solve them. • We don’t necessarily know which category a problem is in. (this is non-computable)

  16. Classifying Computable Problems • Tractable • There is an efficient algorithm to solve the problem. • Intractable • There is an algorithm to solve the problem but there is no efficient algorithm. (This is difficult to prove.)

  17. Examples • Sorting: tractable. • The traveling salesperson problem: intractable. (we think…) • Halting Problem: non-computable. • (More on this later in the week.)

  18. Measuring Efficiency • We are (usually) concerned with the time an algorithm takes to complete. • We count the number of “basic operations” as a function of the size of the input. • Why not measure time directly? • Why not count the number of instructions executed?

  19. Example: Computing an Average def average(array): sum = 0 for x in array: sum += x return sum / len(array) • The statement inside the for loop gets executed len(array) times. • If the length is n, we say this algorithm is “on the order of n”, or, O(n). • O(n)???

  20. Some Mathematical Background • Let’s see some examples …

  21. Big O • The worst case running time, discounting constants and lower order terms. • Example: • n3 + 2n is O(n3)

  22. Tractable vs. Intractable Problems • Problems with polynomial time algorithms are considered tractable. • Problems without polynomial time algorithms are considered intractable. • Eg. Exponential time algorithms. • (More on Friday)

  23. Exchange Sort def exchangeSort(array): for indx1 in range(len(array)): for indx2 in range(indx1, len(array)): if (array[indx1] > array[indx2]): swap(array, indx1, indx2) • Let’s work out the big O running time…

  24. Merge Sort • Given a list, split it into 2 equal piles. • Then split each of these piles in half. Continue to do this until you are left with 1 element in each pile. • Now merge piles back together in order.

  25. Merge Sort • An example of how the merge works: Suppose the first half and second half of an array are sorted: 5 9 10 12 17 1 8 11 20 32 • Merge these by taking a new element from either the first or second subarray, choosing the smallest of the remaining elements. • Big O running time?

  26. Big O Can Be Misleading • Big O analysis is concerned with worst case behavior. • Sometimes we know that we are not dealing with the worst case.

  27. Searching an Array def search(array, key): for x in array: if x == key: return key • Worst case? • Best case?

  28. Binary Search • If we are searching in a sorted list, we choose the half that the value would be in. • We continue to cut the area we are searching in half until we find the value we want, or there are no more values to check. • Worst case? • Best case?

  29. Algorithms Exercise…

More Related