Presentation is loading. Please wait.

Presentation is loading. Please wait.

More Loops Topics Counter-Controlled (Definite) Repetition

Similar presentations


Presentation on theme: "More Loops Topics Counter-Controlled (Definite) Repetition"— Presentation transcript:

1 More Loops Topics Counter-Controlled (Definite) Repetition
Event-Controlled (Indefinite) Repetition for Loops do-while Loops Choosing an Appropriate Loop Break and Continue Statements Reading Sections 5A.4 – 5A.6

2 Counter-Controlled Repetition (Definite Repetition)
If it is known in advance exactly how many times a loop will execute, it is known as a counter-controlled loop. int i = 1 ; while ( i <= 10 ) { printf(“i = %d \n”, i) ; i = i + 1 ; }

3 Counter-Controlled Repetition (con’t)
Is the following loop a counter-controlled loop? while ( x != y ) { printf( “ x = %d ”, x) ; x = x + 2 ; }

4 Event-Controlled Repetition (Indefinite Repetition)
If it is NOT known in advance exactly how many times a loop will execute, it is known as an event-controlled loop. sum = 0 ; printf(“Enter an integer value: ” ) ; scanf(“ %d ”, &value) ; while ( value != -1) { sum = sum + value ; printf(“Enter another value: ” ) ; }

5 Event-Controlled Repetition (con’t)
An event-controlled loop will terminate when some event occurs. The event may be the occurrence of a sentinel value, as in the previous example. There are other types of events that may occur, such as reaching the end of a data file.

6 The 3 Parts of a Loop #include <stdio.h> int main () {
int i = 1 ; initialization of loop control variable /* count from 1 to 100 */ while ( i < 101 ) test condition that terminates loop printf (“%d ”, i) ; i = i + 1 ; modification of loop control } variable return 0 ; }

7 The for Loop Repetition Structure
The for loop handles details of the counter-controlled loop “automatically”. The initialization of the the loop control variable, the termination condition test, and control variable modification are handled in the for loop structure. for ( i = 1; i < 101; i = i + 1) { initialization modification } test

8 When Does a for Loop Initialize, Test and Modify?
Just as with a while loop, a for loop initializes the loop control variable before beginning the first loop iteration, modifies the loop control variable at the very end of each iteration of the loop, and performs the loop termination test before each iteration of the loop. The for loop is easier to write and read for counter-controlled loops.

9 A for Loop That Counts From 0 to 9
for ( i = 0 ; i < 10 ; i = i + 1 ) { printf (“ %d \n ”, i ) ; }

10 We Can Count Backwards, Too
for ( i = 9 ; i >= 0 ; i = i - 1 ) { printf (“ %d \n ”, i ) ; }

11 We Can Count By 2’s ... or 7’s … or Whatever
for ( i = 0 ; i < 10 ; i = i + 2 ) { printf ( “ %d\ n ”, i ) ; }

12 The for can contain arithmetic expressions
x = 2; y =10; for ( j = x; j <= 4 * x * y; j = j + y / x ) { printf(“%d \n”, j ); } is the same as: for ( j = 2; j <= 80; j = j + 5 ) { printf(“%d \n”, j ); }

13 Flowchart of the for structure
i = 1 true counter <= 10 i = i + 1; printf(“%d”, counter); body of the loop may be many statements increment the control variable false

14 The do-while Repetition Structure
{ statement(s) } while ( condition ) ; The body of a do-while is ALWAYS executed at least once. Is this true of a while loop? What about a for loop?

15 Example do { printf (“Enter a positive number: ”) ;
scanf (“%d”, &num) ; if ( num <= 0 ) printf (“\nThat is not positive. Try again\n”) ; } } while ( num <= 0 ) ;

16 The do/while structure
counter = 1 Notice that the loop continuation condition is not executed until after the action is performed at least once. action true condition false

17 An Equivalent while Loop
printf (“Enter a positive number: ”) ; scanf (“%d”, &num) ; while ( num <= 0 ) { printf (“\nThat is not positive. Try again\n”) ; scanf (“ %d ”, &num) ; } Notice that using a while loop in this case requires a priming read.

18 An Equivalent for Loop printf (“Enter a positive number: ”) ; scanf (“%d”, &num) ; for ( ; num <= 0 ; ) { printf (“\nThat is not positive. Try again \n ” ) ; printf (“Enter a positive number: ” ) ; scanf ( “ %d ”, &num) ; } A for loop is a very awkward choice here because the loop is event-controlled.

19 So, Which Type of Loop Should I Use?
Use a for loop for counter-controlled repetition. Use a while or do-while loop for event-controlled repetition. Use a do-while loop when the loop must execute at least one time. Use a while loop when it is possible that the loop may never execute.

20 for loops for specified number of iterations
printf (“Enter the number of students: ”) ; scanf (“%d”, &numStudents); /* we now “know” how many times to loop */ for (student = 1; student <= numStudents; student=student+1) { printf (“ Enter grade: ” ) ; etc. }

21 use while when a condition terminates your loop
the use of a sentinel is a good example...your program doesn’t “know” when the SENTINEL will be encountered printf (“Enter grade: ” ) ; scanf (“%d”, &grade ) ; while (grade != SENTINEL) { etc. }

22 Nested Loops Loops may be nested (embedded) inside of each other.
Actually, any control structure (sequence, selection, or repetition) may be nested inside of any other control structure. It is common to see nested for loops.

23 Nested for Loops for ( i = 1; i < 5; i = i + 1 ) {
for ( j = 1; j < 3; j = j + 1 ) if ( j % 2 == 0 ) printf (“O”) ; } else printf (“X”) ; printf (“\n”) ; How many times is the “if” statement executed? What is the output ?

24 The break Statement The break statement can be used in while, do-while, and for loops to cause premature exit of the loop. THIS IS NOT A RECOMMENDED CODING TECHNIQUE.

25 Example break in a for Loop
#include <stdio.h> int main ( ) { int i ; for ( i = 1; i < 10; i = i + 1 ) if (i == 5) break ; } printf (“%d ”, i) ; printf (“\nBroke out of loop at i = %d.\n”, i) ; return 0 ; OUTPUT: Broke out of loop at i = 5.

26 Example break in a for Loop
#include <stdio.h> int main ( ) { int x, y; for ( x = 1; x < 3; x = x + 1 ) { for ( y = 1; y < 9; y = y + 1) { printf(“x=%d y=%d \n”,x ,y ) ; if ( y = = 3 ) { break ; } return 0 ; OUTPUT: x = 1 y = 1 x = 1 y = 2 x = 1 y = 3 x = 2 y = 1 x = 2 y = 2 x = 2 y = 3

27 The continue Statement
The continue statement can be used in while, do-while, and for loops. It causes the remaining statements in the body of the loop to be skipped for the current iteration of the loop. THIS IS NOT A RECOMMENDED CODING TECHNIQUE.

28 Example continue in a for Loop
#include <stdio.h> int main ( ) { int i ; for ( i = 1; i < 10; i = i + 1 ) if (i == 5) continue ; } printf (“%d ”, i) ; printf ( “ \n Done. \n ” ) ; return 0 ; OUTPUT: Done.

29 Nested for loops How many times is the ‘if’ statement executed?
for (i = 1; i < 5; i = i+1 ) { for (j = 1; j < 3; j = j +1) if (j % 2 == 0) printf (“O”); } else printf (“X”); printf ( “ \n ” ) ; How many times is the ‘if’ statement executed? What is the output ??


Download ppt "More Loops Topics Counter-Controlled (Definite) Repetition"

Similar presentations


Ads by Google