1 Karel – Chapter 6 Instructions That Repeat Note: Original slides provided by www.apComputerScience.com and modified for Mr. Smith’s AP Computer Science.

Slides:



Advertisements
Similar presentations
1 karel_IF_part1 Conditional Statements Flavor 1: if ( ) { } For now: these are method invokations (see next slide)
Advertisements

Karel – Making More Complex Decisions IF / THEN / ELSE IF THEN BEGIN Instructions END ELSE BEGIN Instructions END Do these when test = False Do these when.
Karel – Chapter 6 Instructions That Repeat
Repetition everywhere – comparing while in a method and as an event Susan Rodger Duke University July 2010 modified July 2011.
Copyright, Joseph Bergin
Nested If Statements While Loops
1 karel_part4_functions.ppt Functions Functions return values or Objects. –Using a function allows the programmer to focus on other task. –Using a function.
CMPUT 101 Lab # 2 September 17, :00 – 16:50.
Karel The Robot Nested If Statements While Loops Copyright © 2008 by Helene G. Kershner.
Introduction to Computers and Programming Lecture 9: For Loops New York University.
Conditionals How do we solve tasks in which every particular of a task is not specifically known? – A robot needs the ability to survey its immediate environment.
© 2004 Pearson Addison-Wesley. All rights reserved5-1 Iterations/ Loops The while Statement Other Repetition Statements.
Robot? What’s a Robot? Introducing Karel-the-Robot.
Chapter 5 Conditionally Executing Instructions
1 karel_part5_loops Iteration (Loops) Loops repeat a set of instructions Two types of loops: –Definite loops ( for ) perform instructions explicit (known)
Ch. 2 1 Karel – Primitive Instructions Basic tools with which all problems are solved (analogies: LeftSpinngingRobot, RightSpinningRobot, GuardRobot, etc)
Karel J Robot An introduction to BlueJ and Object- Oriented Programming.
1 Note: Original slides provided by and modified for Mr. Smith’s AP Computer Science A classwww.apComputerScience.com.
1 Ch. 7 Recursion similar to iteration in that you repeatedly do a little bit of the task and then “loop” again and work on a smaller piece - eventually.
C++ for Everyone by Cay Horstmann Copyright © 2012 by John Wiley & Sons. All rights reserved For Loops October 16, 2013 Slides by Evan Gallagher.
Karel the Robot A Gentle Introduction to the Art of Programming.
CPS120 Introduction to Computer Science Iteration (Looping)
Programming Errors Lexical errors – occur whenever Karel reads a word that is not in his vocabulary. Example in English: We are asking directions and instead.
Thanks to Dr. Kris Schindler for this (and all Karel the Robot slides)
Mr. Dave Clausen1 La Cañada High School Chapter 6: Repetition Statements.
Recursion – means to recur or to repeat – A different way to get a robot to repeat an action A programming language that allows recursive definitions (and.
1 Note: Original slides provided by and modified for Mr. Smith’s AP Computer Science A classwww.apComputerScience.com If you.
1 Ch. 6 Iteration (Loops) Loops repeat a set of instructions Two types of loops: –Definite loops ( for ) perform instructions explicit number of times.
1 Karel – Chapter 5 Conditionally Executing Instructions Note: Original slides provided by and modified for Mr. Smith’s AP Computer.
15-100: Introduction to Programming w/ Java * Ananda Gunawardena -- Lecture – School of Computer Science – Phone : (x81559) – Office: Wean Hall.
Chapter 5.  We’ve been using UrRobot – knows only 5 things  Let’s now use a new type of Robot: Robot!  i.e. – public class MileMover extends Robot.
CPS120 Introduction to Computer Science Iteration (Looping)
Introduction to OOP in VB.NET using Robots ACSE Conference, Nov 2004 Michael Devoy Monsignor Doyle C.S.S., Cambridge
1 Note: Original slides provided by and modified for Mr. Smith’s AP Computer Science A classwww.apComputerScience.com.
Structured Programming The Basics. Control structures They control the order of execution What order statements will be done in, or whether they will.
Programming in Karel Eric Roberts CS 106A January 6, 2016.
Ch. 2 1 Karel – Primitive Instructions Basic tools with which all problems are solved (analogies: carpentry, geometry) –move() –turnLeft() –putBeeper()
Karel J. Robot Chapter 6 Instructions That Repeat.
1 Chapter 5 - IF CH5 – Conditional Statements Flavor 1: if ( ) { } For now: these are method invokations (see next slide)
Mile-long hurdle race Suppose that we want to program Karel to run a one-mile long hurdle race, where vertical wall sections represent hurdles. The hurdles.
Karel the Robot – Review Primitive Commands move pickbeeper putbeeper turnleft turnoff Karel’s program statements are separated by a semicolon (;) Copyright.
Repetition everywhere – comparing while in a method and as an event Susan Rodger Duke University July 2010.
1 Karel – Chapter 6 Instructions That Repeat Note: Original slides provided by and modified for Mr. Smith’s AP Computer Science.
1 Karel – Chapter 5 Conditionally Executing Instructions Note: Original slides provided by and modified for Mr. Smith’s AP Computer.
Karel the Robot – Review Primitive Commands move pickbeeper putbeeper turnleft Turnoff Karel’s program statements are separated by a semicolon (;) Copyright.
1 Karel J. Robot Chapter 5 Conditionally Executing Instructions.
Karel J Robot Chapter 5.
1 Chapter 5 Karel J Robot 2 Chapter 5 Chapter 5 Conditional Statements Flavor 1: if ( ) { } For now: these are method invocations (see next slide)
Karel J. Robot Chapter 6 Instructions That Repeat.
CS 106A, Lecture 3 Problem-solving with Karel
Karel – Primitive Instructions
Mile-long hurdle race Suppose that we want to program Karel to run a one-mile long hurdle race, where vertical wall sections represent hurdles. The hurdles.
In the beginning… software
Eric Roberts and Jerry Cain
Copyright © 2008 by Helene G. Kershner
Loops We have already seen instances where a robot needs to repeat instructions to perform a task turnRight(); moveMile(); Harvesting beepers in a field.
Copyright © 2008 by Helene G. Kershner
karel_part4_functions_2
Karel – Primitive Instructions
Karel J Robot.
Karel J Robot Chapter 6.
CS 106A, Lecture 2 Programming with Karel
Karel the Robot – Making Decisions
SSEA Computer Science: CS106A
slides courtesy of Eric Roberts
Unit 1 Test 1 Redo Friday at 8am here or Friday 4th BLOCK in Math Lab
CH5 – Conditional Statements
Nested If Statements While Loops
Iteration (Loops) Loops repeat a set of instructions
Karel – Primitive Instructions
Presentation transcript:

1 Karel – Chapter 6 Instructions That Repeat Note: Original slides provided by and modified for Mr. Smith’s AP Computer Science A classwww.apComputerScience.com

2 while Loop Situation Team up with your neighbor for a couple minutes and discuss a situation that would necessitate that you use a while (indefinite) loop to solve the problem –Note: We might use one or two of these as examples later on when we are discussing while loops.

3 while Loops General form: while ( ) { } Loop continues until test is false

4 while Loops (cont.) Example: while (frontIsClear()) { move(); } Causes the robot to move continuously until there is a wall in front of it

5 while Loops (cont.) Flow of while loops: 1.If test is true, proceed to step 2; if test is false, go to step 4 2.Instructions in body of loop are executed 3.Go to step 1 4.Statements after loop are executed

6 Control structures IterationConditional Definite Loops MethodsSequential Iteration Graphic Organizer Indefinite Loops initialize variabletestincrementtest Types of loops Types of control structures Syntax Examples: for ( int i=1; i<=3; i++ ) { move(); putBeeper(); } while ( frontIsClear() ) { move(); } whilefor Java statement

7 Building a While Loop The following is a more systematic way of creating while loops. This will be extremely helpful to you at various times in the course and on the AP exam. Example: the robot moves until it comes to a beeper and then picks it up Step 1 – Identify what is true when the loop is finished (this is always easier than determining what is false while it is still executing) Step 2 – Use the opposite form of step 1’s result as the for the loop. You just need to negate the entire thing. ( note: Now and again you might find that “DeMorgan- izing” your result is helpful when answering AP-like questions.) Step 3 – make progress toward the goal (completion of the loop) within the loop nextToABeeper() while ( ! nextToABeeper() ) move();

8 Building a while Loop (cont’d) Step 4 – Do whatever is required before and/or after the loop to ensure that we solve the given problem Putting it all together using this 4-step approach: while ( ! nextToABeeper() ) { move(); } pickBeeper(); Another Example: Pick all beepers from a corner without knowing how many there are. pickBeeper();

9 while Loop Exercise Back on an earlier slide, you drew up a situation that would best be solved using a while loop - now write the code to solve your problem If you did not come up with a problem, use the following situation: –The robot should lay down a single beeper on each street corner in a straight line in the direction it is facing until it comes to a wall. In this case it should stop and turn off. –To test this, create a robot on street corner (4, 8) which is facing west, and has 10 beepers in its beeper bag.

10 DeMorgan’s Law Useful in Step 2 for negating the end situation We want to loop until a wall is in front AND a beeper is on the current corner ! frontIsClear() && nextToABeeper() Use DeMorgan’s Law to negate this. Negate the two predicates and replace && with || : while ( frontIsClear || !nextToABeeper() )

11 Let’s build a while loop Move a robot until it is not on a corner with any other robots and there is a wall on the left, then pick up the beeper that will be waiting there (the “hard” part is getting the condition correct without using a trial-and-error method – you don’t get to run any programs during our tests nor on the AP exam – also, you’ll code your labs faster if you have a way to ensure correct conditions EVERY time – without the crutch of running your code) You may use && and || for this exercise. Use the 4-step process now… while (???) { ??? }

12 You try the while condition 1)What is true when the loop is finished? !nextToARobot() && !leftIsClear() 2)Use the opposite form of step 1’s result as the for the loop while (nextToARobot() || leftIsClear()) 3)Make progress toward the goal within loop move(); 4)Do whatever is required before and/or after the loop to ensure that we solve the given problem pickBeeper();

13 You try the while condition You may use && and || for this Write a loop that moves a robot forward until it is either next to a robot, next to a beeper, or there is no wall on its right while ( ??? ) { ??? }

14 You try the while condition 1)What is true when the loop is finished? nextToARobot() || nextToABeeper() || rightIsClear() 2)Use the opposite form of step 1’s result as the for the loop while (!nextToARobot() && !nextToABeeper() && !rightIsClear()) 3)Make progress toward the goal within loop move(); 4)Do whatever is required before and/or after the loop to ensure that we solve the given problem Nothing required

15 Fence Post Problem This is a situation where we must perform some (but not all) of the statements in the loop either before or after the loop to solve the given problem. This is because the instructions in the loop do not entirely solve the problem for either the first time through the loop or the last time through the loop. This is called the Fence Post Problem because if we order 3 fence sections, we actually need 4 fence posts. What if we have five beepers in a row. The robot starts on the same corner as the first beeper. It needs to pick up all 5 beepers and it needs to end up at the corner of the last beeper. How would we go about doing this? for (int i=1; i<=4; i++) { pickBeeper(); move(); } pickBeeper();

16 Fence Post Problem pickBeeper() move()

17 Infinite Loops In a for or while loop, it is possible for the test to never be false When this happens, the loop continues infinitely Depending on the compiler, application, and other circumstances, an error may occur or the app may crash with a memory error