44

Loop Structures and Booleans - University of Michigan

  • Upload
    others

  • View
    8

  • Download
    0

Embed Size (px)

Citation preview

Page 1: Loop Structures and Booleans - University of Michigan
Page 2: Loop Structures and Booleans - University of Michigan

Loop Structures and BooleansZelle - Chapter 8Charles Severance - www.dr-chuck.com

Textbook: Python Programming: An Introduction to Computer Science, John Zelle

Page 3: Loop Structures and Booleans - University of Michigan

Repeated Steps

Output:

01234

Program:

for i in range(5) : print i

i = 0 .. 4i = 0 .. 4

print iprint i

Z-233

Page 4: Loop Structures and Booleans - University of Michigan

Defnite Loops

Page 5: Loop Structures and Booleans - University of Michigan

Defnite Loops

• Loops that run a fxed (aka defnite) number of times

• Loops that “iterate” through an ordered set

• Loops that run “for” a number of times

for abc in range(5) : print “Hi” print abc

Hi0Hi1Hi2Hi3Hi4

Z-39

Page 6: Loop Structures and Booleans - University of Michigan

Defnite Loops

• Loops that run a fxed (aka defnite) number of times

• Loops that “iterate” through an ordered set

• Loops that run “for” a number of times

for abc in range(5) : print “Hi” print abc

Hi0Hi1Hi2Hi3Hi4

Z-39

Colon (:) defines the start of a block. Indenting determines which

lines belong to the block.

Page 7: Loop Structures and Booleans - University of Michigan

Looking at In...• The iteration variable

“iterates” though the sequence (ordered set)

• The block (body) of code is executed once for each value in the sequence

• The iteration variable moves through all of the values in the sequence

for abc in range(5) : ... block of code ...

Iteration variable

Five-element sequence[ 0, 1, 2, 3, 4]

Page 8: Loop Structures and Booleans - University of Michigan

In a FlowChart• The iteration variable

“iterates” though the sequence (ordered set)

• The block (body) of code is executed once for each value in the sequence

• The iteration variable moves through all of the values in the sequence

Page 9: Loop Structures and Booleans - University of Michigan

Program:

for i in range(4) : print i

i = 0i = 0

i = 1i = 1

i = 2i = 2

i = 3i = 3

Loop body is run repeatedly

print iprint i

print iprint i

print iprint i

print iprint i

Page 10: Loop Structures and Booleans - University of Michigan

What is range(10) ?

• range(10) is a built in function that returns a sequence of numbers

• The for statement can iterate through any sequence

• A sequence can have values of different types

Z-40

>>> range(10)[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]>>> for i in [0, 1, 2] :... print I... 012>>> for i in [0, "abc", 9, 2, 3.6] :... print I... 0abc923.6

Page 11: Loop Structures and Booleans - University of Michigan

File Processing

Page 12: Loop Structures and Booleans - University of Michigan

File Processing

• A text fle can be thought of as a sequence of lines

From [email protected] Sat Jan 5 09:14:16 2008Return-Path: <[email protected]>Date: Sat, 5 Jan 2008 09:12:18 -0500To: [email protected]: [email protected]: [sakai] svn commit: r39772 - content/branches/Details: http://source.sakaiproject.org/viewsvn/?view=rev&rev=39772

Z-107

Page 13: Loop Structures and Booleans - University of Michigan

Opening a File

• Before we can read the contents of the fle we must tell Python which fle we are going to work with and what we will be doing with the fle

• This is done with the open() function

• open() returns a “fle handle” - a variable used to perform operations on the fle

• Kind of like “File -> Open” in a Word Processor

Z-108

Page 14: Loop Structures and Booleans - University of Michigan

Using open()

• handle = open(flename, mode)

• returns a handle use to manipulate the fle

• flename is a string

• mode is “r” if we are planning on reading the fle and “w” if we are going to write to the fle.

http://docs.python.org/lib/built-in-funcs.html

fhand = open("mbox.txt", "r")

Z-108

Page 15: Loop Structures and Booleans - University of Michigan

File Handle as a Sequence

• A fle handle open for read can be treated as a sequence of strings where each line in the fle is a string in the sequence

• We can use the for statement to iterate through a sequence

• Remember - a sequence is an ordered set

xfile = open("mbox.txt", "r")

for cheese in xfile: print cheese

Page 16: Loop Structures and Booleans - University of Michigan

Counting Lines in a File

• Open a fle read-only

• Use a for loop to read each line

• Count the lines and print out the number of lines

pizza = open("mbox.txt", "r")

howmany = 0for slice in pizza: howmany = howmany + 1

print howmany

Z-242

Page 17: Loop Structures and Booleans - University of Michigan

What We Do in LoopsNote: Even though these examples are simple the

patterns apply to all kinds of loops

Page 18: Loop Structures and Booleans - University of Michigan

Patterns in Loops

• Counting in loops

• Summing in loops

• Averaging in loops

• Searching in loops

• Detecting in loops

• Largest or smallest

• Using break in a loop

• Using Continue in a loop

Page 19: Loop Structures and Booleans - University of Michigan

Looping through a Set

print “Before”for thing in [3, 41, 12, 9, 74, 15] : print thingprint “After”

$ python basicloop.pyBefore3411297415After

Page 20: Loop Structures and Booleans - University of Michigan

What is the Largest Number?

•3 41 12 9 74 15

Page 21: Loop Structures and Booleans - University of Michigan

What is the Largest Number?

Page 22: Loop Structures and Booleans - University of Michigan

What is the Largest Number?

largest_so_far -13 41 74

Page 23: Loop Structures and Booleans - University of Michigan

Making “smart” loops

• The trick is “knowing” something about the whole loop when you are stuck writing code that only sees one entry at a time

• Favorite dog food…

Set some variables to initial values

For thing in data:

Look for something or do something to each entry separately, updating a

variable.

Look at the variables.

Page 24: Loop Structures and Booleans - University of Michigan

Finding the largest valueLargest = -1print “Before”, largestFor value in [3, 41, 12, 9, 74, 15]: if value > largest: largest = value print largest, value

Print “After”, largest

$ python largest.pyBefore -13 341 4141 1241 974 7474 15After 74

We make a variable that contains the largest value we have seen so far. If the current value is larger, it becomes the new largest value we have seen so far.

Page 25: Loop Structures and Booleans - University of Michigan

Counting in a Loopzork = 0print "Before", zorkfor thing in [3, 41, 12, 9, 74, 15] : zork = zork + 1 print zork, thingprint "After", zork

$ python countloop.py Before 01 32 413 124 95 746 15After 6

To count how many times we execute a loop we introduce a counter variable that starts at 0 and we add one to it each time through the loop.

Page 26: Loop Structures and Booleans - University of Michigan

Summing in a Loopzork = 0print "Before", zorkfor thing in [3, 41, 12, 9, 74, 15] : zork = zork + thing print zork, thingprint "After", zork

$ python countloop.py Before 03 344 4156 1265 9139 74154 15After 154

To add up a value we encounter in a loop, we introduce a sum variable that starts at 0 and we add the value to the sum each time through the loop.

Page 27: Loop Structures and Booleans - University of Michigan

Finding the Average in a Loop

count = 0sum = 0print "Before", count, sumfor value in [3, 41, 12, 9, 74, 15] : count +=1 sum += value print count, sum, valueprint "After", count, sum, sum / count

$ python averageloop.py Before 0 01 3 32 44 413 56 124 65 95 139 746 154 15After 6 154 25

An average just combines the counting and sum patterns and divides when the loop is done.

Page 28: Loop Structures and Booleans - University of Michigan

Searching in a Loop

print "Before“for value in [3, 41, 12, 9, 74, 15] : if value > 20: print "Large number",valueprint "After"

$ python search1.py BeforeLarge number 41Large number 74After

We use an if statement in the loop to catch the values we are looking for.

Page 29: Loop Structures and Booleans - University of Michigan

Did we encounter a value?

found = 0print "Before", foundfor value in [3, 41, 12, 9, 74, 15] : if value == 9: found = 1 print found, valueprint "After", found

$ python search1.py Before 00 30 410 121 91 741 15After 1

If we just want to search and know if a value was found - we use a variable that starts at zero and is set to one as soon as we find what we are looking for.

Page 30: Loop Structures and Booleans - University of Michigan

Using a Boolean Variable

found = Falseprint "Before", foundfor value in [3, 41, 12, 9, 74, 15] : if value == 9: found = True print found, value

print "After", found

$ python search1.py Before FalseFalse 3False 41False 12True 9True 74True 15After True

If we just want to search and know if a value was found - we use a variable that starts at zero and is set to one as soon as we find what we are looking for.

Page 31: Loop Structures and Booleans - University of Michigan

Remembering where...found = Falsewhere = -1count = 0print "Before", foundfor value in [3, 41, 12, 9, 74, 15] : count = count + 1 if value == 9: found = True where = count print found, where, value

print "After", found, where

$ python search1.py Before FalseFalse -1 3False -1 41False -1 12True 4 9True 4 74True 4 15After True 4

Page 32: Loop Structures and Booleans - University of Michigan

Finding the largest value

largest = -1print "Before", largestfor value in [3, 41, 12, 9, 74, 15] : if value > largest : largest = value print largest, value

print "After", largest

$ python largest.py Before -13 341 4141 1241 974 7474 15After 74

We make a variable that contains the largest value we have seen so far. If the current value is larger, it becomes the new largest value we have seen so far.

Page 33: Loop Structures and Booleans - University of Michigan

Finding the smallest valuecount = 0print "Before“for value in [9, 41, 12, 3, 74, 15] : if count == 0 : smallest = value

count = count + 1 if value < smallest : smallest = value print smallest, value

print "After", smallest

$ python smallest.py Before9 99 419 123 33 743 15After 3

We still have a variable that is the smallest so far. The first time through the loop we take the first value to be the smallest.

Page 34: Loop Structures and Booleans - University of Michigan

Breaking out of a loop

print "Before“for value in [3, 41, 12, 9, 74, 15] : print "Loop top",value if value == 12 : break print "Loop bottom", valueprint "After"

$ python breakloop.py BeforeLoop top 3Loop bottom 3Loop top 41Loop bottom 41Loop top 12After

Break immediately terminates the current loop and jumps out of the loop.

break (out)

Page 35: Loop Structures and Booleans - University of Michigan

Breaking out of a loop

print "Before“for value in [3, 41, 12, 9, 74, 15] : print "Loop top",value if value == 12 : break print "Loop bottom", valueprint "After"

$ python breakloop.pyBeforeLoop top 3Loop bottom 3Loop top 41Loop bottom 41Loop top 12After

Break immediately terminates the current loop and jumps out of the loop.

Page 36: Loop Structures and Booleans - University of Michigan

Remembering where the *frst* one

was...

found = Falsewhere = -1count = 0print "Before", foundfor value in [3, 41, 12, 9, 74, 15] : count = count + 1 if value == 9: found = True where = count break print found, valueprint "After", found, where

Page 37: Loop Structures and Booleans - University of Michigan

Continuing with the next iteration

print "Before“for value in [3, 41, 12, 9, 74, 15] : print "Loop top",value if value > 10 : continue print "Loop bottom", valueprint "After"

$ python breakloop.py BeforeLoop top 3Loop bottom 3Loop top 41Loop top 12Loop top 9Loop bottom 9Loop top 74Loop top 15After

Continue immediately terminates the current loop iteration and jumps to the top of the loop and starts the next iteration of the loop.

Page 38: Loop Structures and Booleans - University of Michigan

Continuing with the next iteration

print "Before“for value in [3, 41, 12, 9, 74, 15] : print "Loop top",value if value > 10 : continue print "Loop bottom", valueprint "After"

$ python breakloop.pyBeforeLoop top 3Loop bottom 3Loop top 41Loop top 12Loop top 9Loop bottom 9Loop top 74Loop top 15After

Continue immediately terminates the current loop iteration and jumps to the top of the loop and starts the next iteration of the loop.

Page 39: Loop Structures and Booleans - University of Michigan

Nested Loops $ python nested.py Top 11 X1 YBottom 1Top 22 X2 YBottom 2Top 33 X3 YBottom 3

for out in [1, 2, 3] : print "Top", out for nest in ["X", "Y"] : print out, nest print "Bottom", out

Each time the outer loop runs once, the inner loop runs completely

through the loop.

Page 40: Loop Structures and Booleans - University of Michigan

Boolean Operators and Expressions

Page 41: Loop Structures and Booleans - University of Michigan

Boolean Operations

• We can do calculations with boolean variables just like with integer variables

• The boolean operations are: and or not

• Comparison operators < > <= >= == != return boolean (True or False)

Page 42: Loop Structures and Booleans - University of Michigan

Boolean Operators

( x == 4 ) and (y ==2)

True if both expressions are true.

(x == 4) or (y == 2)

Evaluates to true if either expression is true.

not ( x == 4)

Not “flips” the logic - True becomes False and False becomes True.

Page 43: Loop Structures and Booleans - University of Michigan

Boolean Operation Example

import string

for str in ["bob", "bark at the moon", "where at" ] : words = string.split(str) if len(words) >= 2 and words[1] == "at" :

print "+++++", str else:

print "-----", str$ python findat.py----- bob+++++ bark at the moon+++++ where at

Page 44: Loop Structures and Booleans - University of Michigan

Summary• Loops over a set

• File Loops

• Counting in loops

• Summing in loops

• Averaging in loops

• Searching in loops

• Detecting in loops

• Largest or smallest

• Using break in a loop

• Using continue in a loop

• Boolean operations and, or, not