C++ Programming: From Problem Analysis To Program Design, Fifth Edition
This chapter discusses repetition (looping) control structures in C++, including while, for, and do-while loops. It covers choosing the appropriate loop structure based on needs, using break and continue statements, avoiding bugs through proper design rather than patches, and debugging loops. Nested loops are also presented for generating complex output patterns.
Download as PPT, PDF, TXT or read online on Scribd
0 ratings0% found this document useful (0 votes)
61 views
C++ Programming: From Problem Analysis To Program Design, Fifth Edition
This chapter discusses repetition (looping) control structures in C++, including while, for, and do-while loops. It covers choosing the appropriate loop structure based on needs, using break and continue statements, avoiding bugs through proper design rather than patches, and debugging loops. Nested loops are also presented for generating complex output patterns.
Download as PPT, PDF, TXT or read online on Scribd
You are on page 1/ 32
C++ Programming: From Problem
Analysis to Program Design, Fifth Edition
Chapter 5: Control Structures II
(Repetition) Objectives In this chapter, you will: • Learn about repetition (looping) control structures • Explore how to construct and use count- controlled, sentinel-controlled, flag- controlled, and EOF-controlled repetition structures • Examine break and continue statements • Discover how to form and use nested control structures C++ Programming: From Problem Analysis to Program Design, Fifth Edition 2 Objectives (cont'd.) • Learn how to avoid bugs by avoiding patches • Learn how to debug loops
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 3
Why Is Repetition Needed? • Repetition allows you to efficiently use variables • Can input, add, and average multiple numbers using a limited number of variables • For example, to add five numbers: – Declare a variable for each number, input the numbers and add the variables together – Create a loop that reads a number into a variable and adds it to a variable that contains the sum of the numbers
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 4
while Looping (Repetition) Structure • The general form of the while statement is:
while is a reserved word
• Statement can be simple or compound • Expression acts as a decision maker and is usually a logical expression • Statement is called the body of the loop • The parentheses are part of the syntax
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 5
while Looping (Repetition) Structure (cont'd.)
• Infinite loop: continues to execute endlessly
– Avoided by including statements in loop body that assure exit condition is eventually false
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 6
while Looping (Repetition) Structure (cont'd.)
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 7
Designing while Loops
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 8
Case 1: Counter-Controlled while Loops • If you know exactly how many pieces of data need to be read, – while loop becomes a counter-controlled loop
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 9
Case 2: Sentinel-Controlled while Loops • Sentinel variable is tested in the condition • Loop ends when sentinel is encountered
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 10
Case 3: Flag-Controlled while Loops • A flag-controlled while loop uses a bool variable to control the loop • The flag-controlled while loop takes the form:
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 12
for Looping (Repetition) Structure • The general form of the for statement is:
• The initial statement, loop
condition, and update statement are called for loop control statements – initial statement usually initializes a variable (called the for loop control, or for indexed, variable) • In C++, for is a reserved word C++ Programming: From Problem Analysis to Program Design, Fifth Edition 29 for Looping (Repetition) Structure (cont'd.)
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 30
for Looping (Repetition) Structure (cont'd.)
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 31
for Looping (Repetition) Structure (cont'd.) • C++ allows you to use fractional values for loop control variables of the double type – Results may differ • The following is a semantic error:
• The following is a legal for loop:
for (;;) cout << "Hello" << endl;
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 32
for Looping (Repetition) Structure (cont'd.)
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 33
do…while Looping (Repetition) Structure • General form of a do...while:
• The statement executes first, and then
the expression is evaluated • To avoid an infinite loop, body must contain a statement that makes the expression false • The statement can be simple or compound • Loop always iterates at least once C++ Programming: From Problem Analysis to Program Design, Fifth Edition 34 do…while Looping (Repetition) Structure (cont'd.)
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 35
do…while Looping (Repetition) Structure (cont'd.)
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 36
do…while Looping (Repetition) Structure (cont'd.)
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 37
Example 5-20: Divisibility Test by 3 and 9
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 38
Choosing the Right Looping Structure • All three loops have their place in C++ – If you know or can determine in advance the number of repetitions needed, the for loop is the correct choice – If you do not know and cannot determine in advance the number of repetitions needed, and it could be zero, use a while loop – If you do not know and cannot determine in advance the number of repetitions needed, and it is at least one, use a do...while loop
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 39
break and continue Statements • break and continue alter the flow of control • break statement is used for two purposes: – To exit early from a loop • Can eliminate the use of certain (flag) variables – To skip the remainder of the switch structure • After the break statement executes, the program continues with the first statement after the structure C++ Programming: From Problem Analysis to Program Design, Fifth Edition 40 break and continue Statements (cont'd.) • continue is used in while, for, and do…while structures • When executed in a loop – It skips remaining statements and proceeds with the next iteration of the loop
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 41
Nested Control Structures
• To create the following pattern:
* ** *** **** ***** • We can use the following code: for (i = 1; i <= 5 ; i++) { for (j = 1; j <= i; j++) cout << "*"; cout << endl; } C++ Programming: From Problem Analysis to Program Design, Fifth Edition 42 Nested Control Structures (cont'd.) • What is the result if we replace the first for statement with the following? for (i = 5; i >= 1; i--)
• Answer: ***** **** *** ** *
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 43
Avoiding Bugs by Avoiding Patches • Software patch – Piece of code written on top of an existing piece of code – Intended to fix a bug in the original code • Some programmers address the symptom of the problem by adding a software patch • Should instead resolve underlying issue
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 44
Debugging Loops • Loops are harder to debug than sequence and selection structures • Use loop invariant – Set of statements that remains true each time the loop body is executed • Most common error associated with loops is off-by-one
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 45
ITERATIVE PROGRAM STRUCTURE 1.) Create a flowchart/pseudocode that will generate this character series: Z, Y, X, W, V, A, C, E, G, I 2.) Create a flowchart/pseudocode that will input two numbers base (X) and exponent (Y). Compute and output the result using the formula XY. 3.) Create a flowchart/pseudocode that will input a positive number and output its factorial value. 4.) Create a flowchart/pseudocode that will input ten characters and output how many of the characters entered were alphabetic (A-Z), numeric (0-9), and special character. 5.) Create a flowchart and a pseudocode that display the numbers below: 2, 4, 4, 16, 6, 36, 8, 64, 10, 100 Summary • C++ has three looping (repetition) structures: – while, for, and do…while • while, for, and do are reserved words • while and for loops are called pretest loops • do...while loop is called a posttest loop • while and for may not execute at all, but do...while always executes at least once C++ Programming: From Problem Analysis to Program Design, Fifth Edition 47 Summary (cont'd.)
• while: expression is the decision maker,
and the statement is the body of the loop • A while loop can be: – Counter-controlled – Sentinel-controlled – EOF-controlled • In the Windows console environment, the end-of-file marker is entered using Ctrl+z
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 48
Summary (cont'd.) • for loop: simplifies the writing of a counter-controlled while loop – Putting a semicolon at the end of the for loop is a semantic error • Executing a break statement in the body of a loop immediately terminates the loop • Executing a continue statement in the body of a loop skips to the next iteration
C++ Programming: From Problem Analysis to Program Design, Fifth Edition 49