Programming Logic and Design
Fourth Edition, Comprehensive
Chapter 6Looping
Programming Logic and Design, Introductory, Fourth Edition 2
Objectives
• Understand the advantages of looping
• Control a while loop using a loop control variable
• Increment a counter to control a loop
• Loop with a variable sentinel value
• Control a loop by decrementing a loop control variable
Programming Logic and Design, Introductory, Fourth Edition 3
Objectives (continued)
• Avoid common loop mistakes
• Use a for statement
• Use do while and do until loops
• Recognize the characteristics shared by all loops
• Nest loops
• Use a loop to accumulate totals
Programming Logic and Design, Introductory, Fourth Edition 4
Understanding the Advantages of Looping
• Loop:– Set of instructions that is executed repetitively based
on a condition– Allows processing on large sets of data, such as
complex payroll and benefits processing• Main loop:
– Basic set of instructions that is repeated for every record
Programming Logic and Design, Introductory, Fourth Edition 5
Using a while Loop with a Loop Control Variable
• Loops also occur within program modules
• Three steps in every loop:– Initialize a control variable– Compare the control variable to a value to determine if
the loop should continue– Alter the control variable within the loop
Programming Logic and Design, Introductory, Fourth Edition 6
Using a while Loop with a Loop Control Variable (continued)
Programming Logic and Design, Introductory, Fourth Edition 7
Using a while Loop with a Loop Control Variable (continued)
• Loop control variable: determines whether a loop will continue to execute
• Sentinel value: a limit or ending value to compare with the loop control variable
• Loop body: statements inside the loop that are executed repetitively
• Once the loop body is entered, the entire loop body must execute
• Can exit from a structured loop only at the comparison test of the loop control variable
Programming Logic and Design, Introductory, Fourth Edition 8
Using a Counter to Control Looping
• Developing the application:– The input file
Programming Logic and Design, Introductory, Fourth Edition 9
Using a Counter to Control Looping (continued)
• Developing the application:– The main loop
Programming Logic and Design, Introductory, Fourth Edition 10
Using a Counter to Control Looping (continued)
• Counter: numeric variable that counts how often an event occurs
• Incrementing: adding to a variable, usually by 1
• Loop continues executing until the condition is no longer met
Programming Logic and Design, Introductory, Fourth Edition 11
Using a Counter to Control Looping (continued)
• Developing the application:– housekeeping() module
Programming Logic and Design, Introductory, Fourth Edition 12
Using a Counter to Control Looping (continued)
• Developing the application:– createLabels() module
Programming Logic and Design, Introductory, Fourth Edition 13
Using a Counter to Control Looping (continued)
• Three parts to the loop:– Initialize: Set labelCounter to 0– Compare: compare labelCounter to 100– Body: print labelLine and inFirstName, add 1 to labelCounter
• When labelCounter has a value of 100, the loop ends
• This loop is executed for each employee record
Programming Logic and Design, Introductory, Fourth Edition 14
Using a Counter to Control Looping (continued)
• Developing the application:– finishUp() module
Programming Logic and Design, Introductory, Fourth Edition 15
Looping with a Variable Sentinel Value
• Developing the application– Print labels based on employee’s production amount– The input file:
Programming Logic and Design, Introductory, Fourth Edition 16
Looping with a Variable Sentinel Value (continued)
Programming Logic and Design, Introductory, Fourth Edition 17
Looping by Decrementing
• Decrementing: counting down• May be more convenient to control a loop by
decrementing• May eliminate the need for a counter variable
Programming Logic and Design, Introductory, Fourth Edition 18
Avoiding Common Loop Mistakes
• Neglecting to initialize the loop control variable
• Neglecting to alter the loop control variable
• Using the wrong comparison with the loop control variable
• Including statements inside the loop that belong outside the loop
• Initializing a variable that does not require initialization
Programming Logic and Design, Introductory, Fourth Edition 19
Neglecting to Initialize the Loop Control Variable
• Uninitialized variables may contain unknown, unpredictable garbage
• Makes the comparison for the loop test meaningless
• May fail to enter the loop at all
Programming Logic and Design, Introductory, Fourth Edition 20
Neglecting to Alter the Loop Control Variable
• May cause an infinite loop• Infinite loop: a loop that never stops executing• A structured loop must terminate on its own
Programming Logic and Design, Introductory, Fourth Edition 21
Using the Wrong Comparison with the Loop Control Variable
• Using <= or >= when only < or > was required may cause an extra iteration through the loop
Programming Logic and Design, Introductory, Fourth Edition 22
Including Statements Inside the Loop that Belong Outside the Loop
• A statement erroneously placed in a loop will execute as many times as the loop executes
• Affects the performance and efficiency of the program
• Carefully analyze what actions must be repeated, and place all other actions outside the loop
Programming Logic and Design, Introductory, Fourth Edition 23
Including Statements Inside the Loop that Belong Outside the Loop
(continued)
Programming Logic and Design, Introductory, Fourth Edition 24
Initializing a Variable that Does Not Require Initialization
• Consider whether the variable requires initialization:– Is an initial value required?– Will the variable be assigned a value within the loop?
Programming Logic and Design, Introductory, Fourth Edition 25
Using the for Statement
• Indeterminate (or indefinite) loop: when the number of executions of the loop is not known in advance
• Definite loop: when the number of executions of the loop is known in advance
• while statement can be used with both definite and indefinite loops
• for statement can be used with definite loops
Programming Logic and Design, Introductory, Fourth Edition 26
Using the for Statement (continued)
• for statement performs three actions within a single statement:– Initializes the loop control variable– Evaluates the loop control variable– Alters the loop control variable (usually by
incrementing)
• for statement is a pretest loop
Programming Logic and Design, Introductory, Fourth Edition 27
Using the for Statement (continued)• This for statement accomplishes these tasks:
– Initializes labelCounter to 0– Checks labelCounter to ensure it is less than or
equal to the limit value 99– If the evaluation is true, the loop body is executed
– After executing the loop body, labelCounter is incremented by 1 and compared to the limit value again
Programming Logic and Design, Introductory, Fourth Edition 28
Using the for Statement (continued)
• Use a for statement when the loop will:– Start with a known starting value – End with a known ending value– Increase in equal increments
• Starting, ending and increment values can be represented with variables
• Size of the increment can be set
Programming Logic and Design, Introductory, Fourth Edition 29
Using the do while and do until Loops
• With a pretest loop (for or while), the loop body may never execute
• With a posttest loop, the loop body is always executed at least once
• do while loop continues to execute as long as the condition remains true
• do until loop continues to execute as long as the condition remains false
Programming Logic and Design, Introductory, Fourth Edition 30
Using the do while and do until Loops (continued)
Programming Logic and Design, Introductory, Fourth Edition 31
Using the do while and do until Loops (continued)
Programming Logic and Design, Introductory, Fourth Edition 32
Recognizing the Characteristics Shared by All Loops
• All loops share these characteristics:– Loop-controlling question provides either an entry to or
exit from the repeating structure– Loop-controlling question provides the only entry to or
exit from the repeating structure• Structured loops do not allow premature exits
Programming Logic and Design, Introductory, Fourth Edition 33
Recognizing the Characteristics Shared by All Loops (continued)
Programming Logic and Design, Introductory, Fourth Edition 34
Nesting Loops• Nesting loops: placing one loop inside another loop• Outer loop: a loop that contains another loop• Inner loop: a loop that is inside another loop• Developing the application:
– The input file:
Programming Logic and Design, Introductory, Fourth Edition 35
Nesting Loops (continued)
• Developing the application:– The desired output: ¼ of 1% raise in each pay period– Two pay periods per month
Programming Logic and Design, Introductory, Fourth Edition 36
Nesting Loops (continued)
• Developing the application:– Use two counters:
• One to track months • One to track the checks within the month
– Use constants to self document the program:• Number of months in the year = 12• Number of checks in the month = 2• Rate of pay increase = 0.0025
Programming Logic and Design, Introductory, Fourth Edition 37
Nesting Loops (continued)
Programming Logic and Design, Introductory, Fourth Edition 38
Nesting Loops (continued)
Programming Logic and Design, Introductory, Fourth Edition 39
Using a Loop to Accumulate Totals
• Detail reports: show details, may also show totals or other overall statistics at end
• Summary reports: show only totals or other overall statistics
• Accumulator: a variable used to accumulate values• Accumulator variable must be initialized (usually to 0)
to ensure it does not contain garbage
Programming Logic and Design, Introductory, Fourth Edition 40
Using a Loop to Accumulate Totals (continued)
• Developing the application:– When finished processing the data file, the
accumulator holds the grand total– Summary can then be printed at end of report
Programming Logic and Design, Introductory, Fourth Edition 41
Using a Loop to Accumulate Totals (continued)
Programming Logic and Design, Introductory, Fourth Edition 42
Summary
• Loop: a set of statements that operates on multiple sets of data
• Three steps must occur in a loop: initialize, compare, and alter loop control variable
• Counter: variable used to count the number of times an event occurs
• Sentinel value can be used to control a loop
Programming Logic and Design, Introductory, Fourth Edition 43
Summary (continued)
• Common loop mistakes: – Failing to initialize, or neglecting to alter the loop control
variable– Using the wrong comparison operator– Including statements inside the loop that do not belong
there• for statement: used with definite loops when you
know the number of times the loop will execute• for statement automatically initializes, compares, and
increments its loop control variable
Programming Logic and Design, Introductory, Fourth Edition 44
Summary (continued)
• do while and do until loops: – Test the condition at the end of the loop– Guarantee that the loop body executes at least once
• All structured loops share these characteristics:– Loop controlling question provides either entry to or
exit from the repeating structure– Loop controlling question provides the only entry to
or exit from the repeating structure• Nesting loops: loops placed within other loops• Accumulator: variable used to accumulate values