Chapter 5 Algorithms. 2 Chapter 5: Algorithms 5.1 The Concept of an Algorithm 5.2 Algorithm Representation 5.3 Algorithm Discovery 5.4 Iterative Structures.

Slides:



Advertisements
Similar presentations
Algorithms.
Advertisements

8 Algorithms Foundations of Computer Science ã Cengage Learning.
Sorting Chapter Sorting Consider list x 1, x 2, x 3, … x n We seek to arrange the elements of the list in order –Ascending or descending Some O(n.
Chapter 19: Searching and Sorting Algorithms
Scott Grissom, copyright 2004 Chapter 5 Slide 1 Analysis of Algorithms (Ch 5) Chapter 5 focuses on: algorithm analysis searching algorithms sorting algorithms.
Algorithms and Problem Solving-1 Algorithms and Problem Solving.
Algorithms and Problem Solving. Learn about problem solving skills Explore the algorithmic approach for problem solving Learn about algorithm development.
Chapter 2: Algorithm Discovery and Design
Chapter 2 The Algorithmic Foundations of Computer Science
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 5: Algorithms Computer Science: An Overview Tenth Edition by J. Glenn.
Chapter 2: Algorithm Discovery and Design
Recursion Chapter 7. Chapter 7: Recursion2 Chapter Objectives To understand how to think recursively To learn how to trace a recursive method To learn.
Recursion Chapter 7. Chapter 7: Recursion2 Chapter Objectives To understand how to think recursively To learn how to trace a recursive method To learn.
CHAPTER 10 Recursion. 2 Recursive Thinking Recursion is a programming technique in which a method can call itself to solve a problem A recursive definition.
Chapter 2: Algorithm Discovery and Design
Chapter 2: Algorithm Discovery and Design
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 5: Algorithms Computer Science: An Overview Tenth Edition by J. Glenn.
Copyright © 2012 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 5: Algorithms Computer Science: An Overview Eleventh Edition by J.
HOW TO SOLVE IT? Algorithms. An Algorithm An algorithm is any well-defined (computational) procedure that takes some value, or set of values, as input.
Copyright © 2015 Pearson Education, Inc. Chapter 5: Algorithms.
Simple Program Design Third Edition A Step-by-Step Approach
Problem Solving and Algorithms
Chapter 2: Algorithm Discovery and Design Invitation to Computer Science, C++ Version, Third Edition.
Invitation to Computer Science 6th Edition
Invitation to Computer Science, Java Version, Second Edition.
Recursion Chapter 7. Chapter Objectives  To understand how to think recursively  To learn how to trace a recursive method  To learn how to write recursive.
Chapters 7, 8, & 9 Quiz 3 Review 1. 2 Algorithms Algorithm A set of unambiguous instructions for solving a problem or subproblem in a finite amount of.
Chapter 12 Recursion, Complexity, and Searching and Sorting
Chapter 06 (Part I) Functions and an Introduction to Recursion.
Chapter 5 Algorithms © 2007 Pearson Addison-Wesley. All rights reserved.
“The study of algorithms is the cornerstone of computer science.” Algorithms Fall 2011.
Chapter 5 Algorithms Introduction to computer, 2nd semester, 2010/2011 Mr.Nael Aburas Faculty of Information Technology.
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 5: Algorithms Computer Science: An Overview Tenth Edition by J. Glenn.
Problem Solving Techniques. Compiler n Is a computer program whose purpose is to take a description of a desired program coded in a programming language.
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 5: Algorithms Computer Science: An Overview Tenth Edition by J. Glenn.
Algorithm: definition An algorithm is an ordered set of unambiguous, executable steps that defines a terminating process.
Chapter 5 Algorithms. © 2005 Pearson Addison-Wesley. All rights reserved 5-2 Chapter 5: Algorithms 5.1 The Concept of an Algorithm 5.2 Algorithm Representation.
Chapter 5: 演算法 Algorithms 陳以德助理教授 : 高醫大舊二棟 轉 2586
Searching Chapter 18 © 2015 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. Data Structures and Abstractions with Java, 4e Frank.
Copyright © 2008 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 5: Algorithms Computer Science: An Overview Tenth Edition by J. Glenn.
Chapter 5 Algorithms © 2007 Pearson Addison-Wesley. All rights reserved.
Computer Science: An Overview Eleventh Edition
Chapter 8 Algorithms.
8.1 8 Algorithms Foundations of Computer Science  Cengage Learning.
Invitation to Computer Science 5 th Edition Chapter 2 The Algorithmic Foundations of Computer Science.
INVITATION TO Computer Science 1 11 Chapter 2 The Algorithmic Foundations of Computer Science.
Loop Invariants and Binary Search Chapter 4.4, 5.1.
CMPSC 16 Problem Solving with Computers I Spring 2014 Instructor: Tevfik Bultan Lecture 4: Introduction to C: Control Flow.
Chapter 2: Algorithm Discovery and Design Invitation to Computer Science.
PROGRAMMING FUNDAMENTALS INTRODUCTION TO PROGRAMMING. Computer Programming Concepts. Flowchart. Structured Programming Design. Implementation Documentation.
Algorithms and Problem Solving. Learn about problem solving skills Explore the algorithmic approach for problem solving Learn about algorithm development.
Chapter 16: Searching, Sorting, and the vector Type.
Chapter 16: Searching, Sorting, and the vector Type
Introduction to Algorithms
Algorithms and Problem Solving
Q & A.
Computer Science: An Overview Eleventh Edition
Chapter 5: Algorithms 5.1 The Concept of an Algorithm
PROBLEM SOLVING SKILLS
Chapter 5: Algorithms Computer Science: An Overview Tenth Edition
Computer Science — An Overview J. Glenn Brookshear
Algorithms and Problem Solving
Introduction to Algorithms
Computer Science: An Overview Tenth Edition
Presentation transcript:

Chapter 5 Algorithms

2 Chapter 5: Algorithms 5.1 The Concept of an Algorithm 5.2 Algorithm Representation 5.3 Algorithm Discovery 5.4 Iterative Structures 5.5 Recursive Structures 5.6 Efficiency and Correctness

3 Algorithm: definition An algorithm is an ordered set of unambiguous, executable steps that defines a terminating process.

4 Algorithms: levels of abstraction Problem = motivation for algorithm Algorithm = procedure to solve the problem Often one of many possibilities Representation = description of algorithm sufficient to communicate it to the desired audience Always one of many possibilities

5 Figure 5.2 Folding a bird from a square piece of paper

6 Figure 5.3 Origami primitives

7 Pseudocode primitives Assignment name  expression Conditional selection if condition then action Repeated execution while condition do activity Procedure procedure name (generic names)

8 Figure 5.4 The procedure Greetings in pseudocode

9 Problem solving steps 1. Understand the problem. 2. Get an idea how an algorithmic procedure might solve the problem. 3. Formulate the algorithm and represent it as a program. 4. Evaluate the program for accuracy and its potential as a tool for solving other problems.

10 Problem solving steps To solve a problem, one must take the initiative and lead to go through the stepwise refinement of attempted solutions toward a true understanding of a problem. An incubation period is the time span between conscious work on a problem and sudden (mysterious) inspiration– “Aha!”experience.

11 Techniques for “getting a foot in the door” Work the problem backwards Solve an easier related problem Relax some of the problem constraints Solve pieces of the problem first = bottom up methodology Stepwise refinement = top-down methodology Popular technique because it produces modular programs

12 Sample problem Person A is charged with the task of determining the ages of B ’ s three children. B tells A that the product of the children ’ s ages is 36. A replies that another clue is required. B tells A the sum of the children ’ s ages. A replies that another clue is needed. B tells A that the oldest child plays the piano. A tells B the ages of the three children. How old are the three children?

13 Figure 5.5

14 Iterative Structure Iterative structures --repeat collections of instructions in a looping manner. In contrast, recursive structures recur the same block of codes with the finer scope in a convergent fashion. Iterative structures can be converted into recursive structures, and vice verse.

15 Figure 5.7 Components of repetitive control

16 Iterative Structure There are four kinds of code blocks in iterative structures: Initialize: establish an initial state to be modified toward the termination condition. Test: compare the current state if the termination condition is reached. Statement: is the same block simply repeated in each iteration. Modify: change the state toward the termination condition.

17 Flow Chart Conditional loop: while (condition) do(activity) While there are tickets to sell, keep selling tickets. while (tickets remain to be sold) do(sell a ticket)

18 Iterative Structure For-loop: for( initialize; test; modify ) { statement; } While-loop: initialize; while( test ) { statement; modify; } Repeat-loop: initialize; repeat ( statement; modify; ) until ( test ) For-loop is similar to while-loop; repeat-loop uses the negation of their test condition to terminate the loop. Iterative structures are used to avoid writing the instructions several times explicitly (tediously). Several classical search algorithms are popular exemplars.

19 Flow Chart Conditional branch: if (condition) then(activity 1) else(activity 2) Divide the total by 366 or 365 dependent on the year is a leap year or not. if (year is leap year) then(divide total by 366) else(divide total by 365) if (year is leap year) then(divide total by 366) else(divide total by 365) ⇐ Indentation and parentheses for readability!!

20 Figure 5.8 The while loop structure

21 Figure 5.9 The repeat loop structure

22 Flow Chart It is used to find the particular one from some sorted list. Sorting algorithms can sort the list in an ascending or descending order.The search terminates as a success if the target is found, or a failure if none is found at the end of the list.E.g., search a guest list of perhaps 20 entries for a particular name:

23 Figure 5.6 The sequential search algorithm in pseudocode

24 Insertion sort algorithm It sorts a list by repeatedly removing an entry and inserting it into its proper place. Taking the first one from the unsorted sub-list to the sorted sub-list Figure 5.10 Sorting the list Fred, Alex, Diana, Byron, and Carol alphabetically

25 Figure 5.11 The insertion sort algorithm expressed in pseudocode

26 Recursive Structure Recursive structures provide an alternative to the loop paradigm for repetitive structures (by invoking itself). The execution of a recursive algorithm creates multiple instances (children) of itself, called activations, which are born to conquer revised smaller problems and return the results back to the calling parent. Only one instance is actively progressing. Like those in loop control, a recursive routine has the base or degenerate case to test for the termination condition. If met, the current activation returns to resume dormant parent activation.

27 Figure 5.12 Applying our strategy to search a list for the entry John

28 Figure 5.13 A first draft of the binary search technique

29 Figure 5.14 The binary search algorithm in pseudocode

30 Figure 5.15(Serach for Bill)

31 Figure 5.16(Search for David)

32 Figure 5.17

33 Software efficiency Measured as number of instructions executed  notation for efficiency classes Example: insertion sort is  (n 2 ) Best, worst, and average case

34 Figure 5.18 Applying the insertion sort in a worst-case situation The worst case occurs when the original list is in reverse Order such that N-1=O(N(N-1)/2)=>O(N^2) The average case:each pivot compares to half of the entries Preceding of it. O(N(N-1)/4)

35 Figure 5.19 Graph of the worst-case analysis of the insertion sort algorithm

36 Figure 5.20 Graph of the worst-case analysis of the binary search algorithm  (logn) <  (n)<  (nlogn)<  (n 2 )

37 Example problem: Chain separating A traveler has a gold chain of seven links. He must stay at an isolated hotel for seven nights. The rent each night consists of one link from the chain. What is the fewest number of links that must be cut so that the traveler can pay the hotel one link of the chain each morning without paying for lodging in advance?

38 Figure 5.21 Separating the chain using only three cuts

39 Figure 5.22 Solving the problem with only one cut

40 Software verification Proof of correctness Preconditions are the conditions that are satisfied at the beginning of the program ’ s execution. Assertions are the statements that are established at various points in the program as the consequences of preconditions. The assertion built at the end of the program corresponds to the desired output specifications. Loop invariants are the assertions during the repetitive process. They ensure the modification components operate correctly. IC designs (hardware) have similar endeavors of developing a generic set of test cases. Testing

41 Figure 5.23 The assertions associated with a typical while structure