0% found this document useful (0 votes)
34 views

03 Gaddis Python Lecture PPT Ch03

This chapter discusses decision structures and Boolean logic in Python. It covers if, if-else, and if-elif-else statements for conditionally executing code. Logical operators like and, or, and not are presented for combining Boolean expressions. String comparison and nested conditional blocks are also reviewed. The key topics are syntactic structures and logical concepts for controlling program flow based on conditional testing in Python.

Uploaded by

JTN TEC
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
34 views

03 Gaddis Python Lecture PPT Ch03

This chapter discusses decision structures and Boolean logic in Python. It covers if, if-else, and if-elif-else statements for conditionally executing code. Logical operators like and, or, and not are presented for combining Boolean expressions. String comparison and nested conditional blocks are also reviewed. The key topics are syntactic structures and logical concepts for controlling program flow based on conditional testing in Python.

Uploaded by

JTN TEC
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
You are on page 1/ 39

Starting out with Python

Fifth Edition, Global Edition

Chapter 3
Decision Structures and
Boolean Logic

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-1


Topics
• The if Statement
• The if-else Statement
• Comparing Strings
• Nested Decision Structures and the if-elif-else
Statement
• Logical Operators
• Boolean Variables
• Turtle Graphics: Determining the State of the Turtle

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-2


The if Statement (1 of 4)
• Control structure: logical design that controls order in
which set of statements execute
• Sequence structure: set of statements that execute in
the order they appear
• Decision structure: specific action(s) performed only if
a condition exists
– Also known as selection structure

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-3


The if Statement (2 of 4)
• In flowchart, diamond represents true/false condition
that must be tested
• Actions can be conditionally executed
– Performed only when a condition is true
• Single alternative decision structure: provides only
one alternative path of execution
– If condition is not true, exit the structure

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-4


The if Statement (3 of 4)

Figure 3-1 A simple decision structure

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-5


The if Statement (4 of 4)
• Python syntax:
if condition:
Statement
Statement
• First line known as the if clause
– Includes the keyword if followed by condition
 The condition can be true or false
 When the if statement executes, the condition is tested,
and if it is true the block statements are executed.
otherwise, block statements are skipped

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-6


Boolean Expressions and Relational
Operators (1 of 5)
• Boolean expression: expression tested by if statement
to determine if it is true or false
– Example: a > b
 true if a is greater than b; false otherwise

• Relational operator: determines whether a specific


relationship exists between two values
– Example: greater than (>)

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-7


Boolean Expressions and Relational
Operators (2 of 5)
• >= and <= operators test more than one relationship
– It is enough for one of the relationships to exist for the
expression to be true
• == operator determines whether the two operands are
equal to one another
– Do not confuse with assignment operator (=)
• != operator determines whether the two operands are
not equal

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-8


Boolean Expressions and Relational
Operators (3 of 5)
Table 3-2 Boolean expressions using relational operators
Expression Meaning
x > y Is x greater than y?
x < y Is x less than y?
x >= y Is x greater than or equal to y?
x <= y Is x less than or equal to y?
x == y Is x equal to y?
x != y Is x not equal to y?

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3-9


Boolean Expressions and Relational
Operators (4 of 5)
• Using a Boolean expression with the > relational
operator

Figure 3-3 Example decision structure

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 10


Boolean Expressions and Relational
Operators (5 of 5)
• Any relational operator can be used in a decision
block
– Example: if balance == 0
– Example: if payment != balance
• It is possible to have a block inside another block
– Example: if statement inside a function
– Statements in inner block must be indented with
respect to the outer block

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 11


The if-else Statement (1 of 3)
• Dual alternative decision structure: two possible paths
of execution
– One is taken if the condition is true, and the other if the
condition is false
– Syntax: if condition:
statements
else:
other statements
– if clause and else clause must be aligned
– Statements must be consistently indented

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 12


The if-else Statement (2 of 3)

Figure 3-5 A dual alternative decision structure

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 13


The if-else Statement (3 of 3)

Figure 3-6 Conditional execution in an if-else statement

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 14


Comparing Strings (1 of 2)
• Strings can be compared using the == and !=
operators
• String comparisons are case sensitive
• Strings can be compared using >, <, >=, and <=
– Compared character by character based on the ASCII
values for each character
– If shorter word is substring of longer word, longer word
is greater than shorter word

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 15


Comparing Strings (2 of 2)

Figure 3-9 Comparing each character in a string

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 16


Nested Decision Structures and the
if-elif-else Statement (1 of 3)
• A decision structure can be nested inside another
decision structure
– Commonly needed in programs
– Example:
 Determine if someone qualifies for a loan, they must
meet two conditions:
– Must earn at least $30,000/year
– Must have been employed for at least two years
 Check first condition, and if it is true, check second
condition

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 17


Nested Decision Structures and the
if-elif-else Statement (2 of 3)

Figure 3-12 A nested decision structure

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 18


Nested Decision Structures and the
if-elif-else Statement (3 of 3)
• Important to use proper indentation in a nested
decision structure
– Important for Python interpreter
– Makes code more readable for programmer
– Rules for writing nested if statements:
 else clause should align with matching if clause
 Statements in each block must be consistently indented

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 19


The if-elif-else Statement (1 of 3)
• if-elif-else statement: special version of a
decision structure
– Makes logic of nested decision structures simpler to
write
 Can include multiple elif statements
– Syntax: if condition_1:
statement(s)
elif condition_2:
statement(s) Insert as many elif clauses
elif condition_3: as necessary.
statement(s)
else
statement(s)

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 20


The if-elif-else Statement (2 of 3)
• Alignment used with if-elif-else statement:
– if, elif, and else clauses are all aligned
– Conditionally executed blocks are consistently indented
• if-elif-else statement is never required, but logic
easier to follow
– Can be accomplished by nested if-else
 Code can become complex, and indentation can cause
problematic long lines

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 21


The if-elif-else Statement (3 of 3)

Figure 3-15 Nested decision structure to determine a grade

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 22


Logical Operators
• Logical operators: operators that can be used to
create complex Boolean expressions
– and operator and or operator: binary operators,
connect two Boolean expressions into a compound
Boolean expression
– not operator: unary operator, reverses the truth of its
Boolean operand

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 23


The and Operator
• Takes two Boolean expressions as operands
– Creates compound Boolean expression that is true only
when both sub expressions are true
– Can be used to simplify nested decision structures
• Truth table for the and operator
Value of the Expression
Expression
false false and false
false false and true
false true and false
true true and true

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 24


The or Operator
• Takes two Boolean expressions as operands
– Creates compound Boolean expression that is true
when either of the sub expressions is true
– Can be used to simplify nested decision structures
• Truth table for the or operator
Value of the Expression
Expression
false false and false
true false and true
true true and false
true true and true

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 25


Short-Circuit Evaluation
• Short circuit evaluation: deciding the value of a
compound Boolean expression after evaluating only
one sub expression
– Performed by the or and and operators
 For or operator: If left operand is true, compound
expression is true. Otherwise, evaluate right operand
 For and operator: If left operand is false, compound
expression is false. Otherwise, evaluate right operand

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 26


The not Operator
• Takes one Boolean expressions as operand and
reverses its logical value
– Sometimes it may be necessary to place parentheses
around an expression to clarify to what you are
applying the not operator
• Truth table for the not operator

Value of the Expression Expression


false true
true false

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 27


Checking Numeric Ranges with Logical
Operators
• To determine whether a numeric value is within a
specific range of values, use and
– Example: x >= 10 and x <= 20
• To determine whether a numeric value is outside of a
specific range of values, use or
– Example: x < 10 or x > 20

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 28


Boolean Variables
• Boolean variable: references one of two values, True
or False
– Represented by bool data type
• Commonly used as flags
– Flag: variable that signals when some condition exists
in a program
 Flag set to False  condition does not exist
 Flag set to True  condition exists

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 29


Turtle Graphics: Determining the State
of the Turtle (1 of 9)
• The turtle.xcor() and turtle.ycor() functions
return the turtle's X and Y coordinates
• Examples of calling these functions in an if
statement:
if turtle.ycor() < 0:
turtle.goto(0, 0)

if turtle.xcor() > 100 and turtle.xcor() < 200:


turtle.goto(0, 0)

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 30


Turtle Graphics: Determining the State
of the Turtle (2 of 9)
• The turtle.heading() function returns the turtle's
heading. (By default, the heading is returned in degrees.)
• Example of calling the function in an if statement:

if turtle.heading() >= 90 and turtle.heading() <= 270:


turtle.setheading(180)

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 31


Turtle Graphics: Determining the State
of the Turtle (3 of 9)
• The turtle.isdown() function returns True if the
pen is down, or False otherwise.
• Example of calling the function in an if statement:

if turtle.isdown():
turtle.penup()

if not(turtle.isdown()):
turtle.pendown()

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 32


Turtle Graphics: Determining the State
of the Turtle (4 of 9)
• The turtle.isvisible() function returns True if
the turtle is visible, or False otherwise.
• Example of calling the function in an if statement:

if turtle.isvisible():
turtle.hideturtle()

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 33


Turtle Graphics: Determining the State
of the Turtle (5 of 9)
• When you call turtle.pencolor() without passing an
argument, the function returns the pen's current color as a
string. Example of calling the function in an if statement:
if turtle.pencolor() == 'red':
turtle.pencolor('blue')

• When you call turtle.fillcolor() without passing


an argument, the function returns the current fill color as a
string. Example of calling the function in an if statement:
if turtle.fillcolor() == 'blue':
turtle.fillcolor('white')

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 34


Turtle Graphics: Determining the State
of the Turtle (6 of 9)
• When you call turtle.bgcolor() without passing
an argument, the function returns the current
background color as a string. Example of calling the
function in an if statement:

if turtle.bgcolor() == 'white':
turtle.bgcolor('gray')

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 35


Turtle Graphics: Determining the State
of the Turtle (7 of 9)
• When you call turtle.pensize() without passing an
argument, the function returns the pen's current size as a
string. Example of calling the function in an if statement:

if turtle.pensize() < 3:
turtle.pensize(3)

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 36


Turtle Graphics: Determining the State
of the Turtle (8 of 9)
• When you call turtle.speed()without passing an
argument, the function returns the current animation
speed. Example of calling the function in an if statement:

if turtle.speed() > 0:
turtle.speed(0)

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 37


Turtle Graphics: Determining the State
of the Turtle (9 of 9)
• See In the Spotlight: The Hit the Target Game in your
textbook for numerous examples of determining the
state of the turtle.

Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 38


Summary
• This chapter covered:
– Decision structures, including:
 Single alternative decision structures
 Dual alternative decision structures
 Nested decision structures
– Relational operators and logical operators as used in
creating Boolean expressions
– String comparison as used in creating Boolean
expressions
– Boolean variables
– Determining the state of the turtle in Turtle Graphics
Copyright © 2022 Pearson Education, Ltd. All Rights Reserved. 3 - 39

You might also like