Download presentation
Presentation is loading. Please wait.
Published byCharlotte Garrison Modified over 8 years ago
1
Instructor: Alexander Stoytchev http://www.ece.iastate.edu/~alexs/classes/2009_Fall_185/ CprE 185: Intro to Problem Solving (using C)
2
Loops (part 1) CprE 185: Intro to Problem Solving Iowa State University, Ames, IA Copyright © Alexander Stoytchev
3
Administrative Stuff Midterm grades due next Friday Oct 17 Please double check your grades on Web CT
4
Administrative Stuff HW5 is out (due next Wed, Oct 15 @ 8pm) HW4 is due this Wed, Oct 8 @ 8pm
5
Quick Review of Last Lecture
6
The switch Statement The switch statement provides another way to decide which statement to execute next The switch statement evaluates an expression, then attempts to match the result to one of several possible cases Each case contains a value and a list of statements The flow of control transfers to statement associated with the first case value that matches
7
The switch Statement Often a break statement is used as the last statement in each case's statement list A break statement causes control to transfer to the end of the switch statement If a break statement is not used, the flow of control will continue into the next case Sometimes this may be appropriate, but often we want to execute only the statements associated with one case
8
The switch Statement switch (option) { case 'A': aCount++; break; case 'B': bCount++; break; case 'C': cCount++; break; default: otherCount++; break; } An example of a switch statement:
9
The switch Statement A switch statement can have an optional default case The default case has no associated value and simply uses the reserved word default If the default case is present, control will transfer to it if no other case value matches If there is no default case, and no other value matches, control falls through to the statement after the switch
10
The switch Statement The expression of a switch statement must result in an integral type, meaning an integer ( byte, short, int,) or a char It cannot be a floating point value ( float or double ) The implicit test condition in a switch statement is equality You cannot perform relational checks with a switch statement
11
The switch Statement The general syntax of a switch statement is: switch ( expression ) { case value1 : statement-list1 case value2 : statement-list2 case value3 : statement-list3 case... } switch and case are reserved words If expression matches value2, control jumps to here
12
Chapter 5 (Loops)
13
Repetition Statements Repetition statements allow us to execute a statement multiple times Often they are referred to as loops C has three kinds of repetition statements: the while loop the do loop the for loop The programmer should choose the right kind of loop for the situation © 2004 Pearson Addison-Wesley. All rights reserved
14
There are three loop constructs in C do-while loop (or do loop for short) while loop for loop We’ll quickly cover all of them today. We’ll revisit them again next time. Loops = repetition statements
15
Logic of an if statement condition evaluated statement true false © 2004 Pearson Addison-Wesley. All rights reserved
16
Logic of a do Loop true condition evaluated statement false © 2004 Pearson Addison-Wesley. All rights reserved
17
The do Statement A do statement has the following syntax: do { statement; } while ( condition ); The statement is executed once initially, and then the condition is evaluated The statement is executed repeatedly until the condition becomes false © 2004 Pearson Addison-Wesley. All rights reserved
18
The do Statement An example of a do loop: The body of a do loop is executed at least once int count = 0; do { count++; printf(“%d\n”, count); } while (count < 5); © 2004 Pearson Addison-Wesley. All rights reserved
19
Example: Fixing Bad Keyboard Input Write a program that refuses to accept a negative number as an input. The program must keep asking the user to enter a value until he/she enters a positive number. How can we do this?
20
Example: Reverse a number
21
Logic of a while Loop statement true false condition evaluated © 2004 Pearson Addison-Wesley. All rights reserved
22
The while Statement A while statement has the following syntax: while ( condition ) statement; If the condition is true, the statement is executed Then the condition is evaluated again, and if it is still true, the statement is executed again The statement is executed repeatedly until the condition becomes false © 2004 Pearson Addison-Wesley. All rights reserved
23
The while Statement An example of a while statement: int count = 1; while (count <= 5) { printf (“%d\n”, count); count++; } If the condition of a while loop is false initially, the statement is never executed Therefore, the body of a while loop will execute zero or more times © 2004 Pearson Addison-Wesley. All rights reserved
24
The while Statement Let's look at some examples of loop processing A loop can be used to maintain a running sum A sentinel value is a special input value that represents the end of input A loop can also be used for input validation, making a program more robust © 2004 Pearson Addison-Wesley. All rights reserved
25
Comparing while and do statement true false condition evaluated The while Loop true condition evaluated statement false The do Loop © 2004 Pearson Addison-Wesley. All rights reserved
26
Logic of a for loop statement true condition evaluated false increment initialization © 2004 Pearson Addison-Wesley. All rights reserved
27
The for Statement A for statement has the following syntax: for ( initialization ; condition ; increment ) statement; The initialization is executed once before the loop begins The statement is executed until the condition becomes false The increment portion is executed at the end of each iteration © 2004 Pearson Addison-Wesley. All rights reserved
28
The for Statement A for loop is functionally equivalent to the following while loop structure: initialization; while ( condition ) { statement; increment; } © 2004 Pearson Addison-Wesley. All rights reserved
29
The for Statement An example of a for loop: for (int count=1; count <= 5; count++) printf (“%d\n”, count); The initialization section can be used to declare a variable Like a while loop, the condition of a for loop is tested prior to executing the loop body Therefore, the body of a for loop will execute zero or more times © 2004 Pearson Addison-Wesley. All rights reserved
30
The for Statement The increment section can perform any calculation A for loop is well suited for executing statements a specific number of times that can be calculated or determined in advance Int num; for (num=100; num > 0; num -= 5) printf (“%d\n”, num); © 2004 Pearson Addison-Wesley. All rights reserved
31
The for Statement Each expression in the header of a for loop is optional If the initialization is left out, no initialization is performed If the condition is left out, it is always considered to be true, and therefore creates an infinite loop If the increment is left out, no increment operation is performed © 2004 Pearson Addison-Wesley. All rights reserved
32
Example: Multiplication Table © 2004 Pearson Addison-Wesley. All rights reserved
33
Example: Stars Write a program that prints the following * ** *** **** ***** ****** ******* ******** ********* ********** © 2004 Pearson Addison-Wesley. All rights reserved
34
Example: Stars Write a program that prints the following * ** *** **** ***** ****** ******* ******** ********* ********** © 2004 Pearson Addison-Wesley. All rights reserved
35
Infinite Loops The body of a while loop eventually must make the condition false If not, it is called an infinite loop, which will execute until the user interrupts the program This is a common logical error You should always double check the logic of a program to ensure that your loops will terminate normally © 2004 Pearson Addison-Wesley. All rights reserved
36
Infinite Loops An example of an infinite loop: int count = 1; while (count <= 25) { printf (“%d\n”, count); count = count - 1; } This loop will continue executing until interrupted (Control-C) or until an underflow error occurs © 2004 Pearson Addison-Wesley. All rights reserved
37
Nested Loops Similar to nested if statements, loops can be nested as well That is, the body of a loop can contain another loop For each iteration of the outer loop, the inner loop iterates completely © 2004 Pearson Addison-Wesley. All rights reserved
38
Nested Loops How many times will the string "Here" be printed? count1 = 1; while (count1 <= 10) { count2 = 1; while (count2 <= 20) { printf ("Here"); count2++; } count1++; } 10 * 20 = 200 © 2004 Pearson Addison-Wesley. All rights reserved
39
Analogy for Nested Loops http://www.brandondufau.com/archives/odometer%201.jpg
40
Analogy for Nested Loops http://static.howstuffworks.com/gif/odometer2.jpg Inner Loop Outer Loop
41
break
42
continue
43
THE END
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.