python programming: an introduction to computer sciencemercer/ista130/... · python programming,...

23
Python Programming, 2/e 1 Python Programming: An Introduction to Computer Science Chapter 6 Defining Functions

Upload: others

Post on 05-Jun-2020

10 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 1

Python Programming:An Introduction toComputer Science

Chapter 6

Defining Functions

Page 2: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 2

Objectives

To understand why programmers divide programs up into sets of cooperating functions.

To be able to define new functions in Python.

To understand the details of function calls and parameter passing in Python.

Page 3: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 3

Objectives (cont.)

To write programs that use functions to reduce code duplication and increase program modularity.

Page 4: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 4

The Function of Functions

So far, we’ve seen three different types of functions: Our programs comprise a single function

called main().

Built-in Python functions (round, abs)

Functions from the standard libraries (math.sqrt, math.sin)

Page 5: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 5

The Function of Functions

Having similar or identical code in more than one place has some drawbacks. Issue one: writing the same code twice or

more.

Issue two: This same code must be maintained in two separate places.

Functions can be used to reduce code duplication and make programs more easily understood and maintained.

Page 6: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 6

Functions, Informally

A function is like a subprogram, a small program inside of a program.

The basic idea – we write a sequence of

statements and then give that sequence a name. We can then execute this sequence at any time by referring to the name.

Page 7: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 7

Functions, Informally

The part of the program that creates a function is called a function definition.

When the function is used in a program, we say the definition is calledor invoked.

Page 8: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 8

Functions, Informally

Example of function (intentional bug)# Using a main method like the book

# This code has an intentional bug

def main():

a, b, c = eval(input("Enter 3 numbers: "))

if(a >= b >= c):

max = a;

if(b >= a >= c):

max = b;

if(c >= b >= a):

max = a;

print('Max: ', max)

main()

Page 9: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 9

Functions, Informally

Let's put the buggy ifs in a new functiondef maxOf3(a, b, c):

if(a >= b >= c):

max = a;

if(b >= a >= c):

max = b;

if(c >= b >= a):

max = a;

return max

def main():

a, b, c = eval(input("Enter 3 numbers: "))

print('Max: ', maxOf3(a, b, c))

main()

Page 10: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 10

Functions, Informally

Change main to test the new functiondef main():

# All permutations of three unique numbers

print('3? ', maxOf3(1, 2, 3))

print('3? ', maxOf3(1, 3, 2))

print('3? ', maxOf3(2, 3, 1))

print('3? ', maxOf3(2, 1, 3))

# The other two?

Page 11: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 11

Functions, Informally

Creating this function captured the logic

If we can get this function working, it would be nice.

Debug and test it now.

Page 12: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 12

Functions and Parameters: The Details

Each function is its own little subprogram. The variables used inside of a function are local to that function, even if they happen to have the same name as variables that appear inside of another function.

The only way for a function to see a variable or to get a value from another place is for that variable to be passed as a parameter.

Page 13: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 13

Functions and Parameters: The Details

A function definition looks like this:def <name>(<formal-parameters>):

<body>

The name of the function must be an identifier

Formal-parameters is a possibly empty list of variable names

Page 14: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 14

Functions and Parameters: The Details

Formal parameters, like all variables used in the function, are only accessible in the body of the function. Variables with identical names elsewhere in the program are distinct from the formal parameters and variables inside of the function body.

Page 15: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 15

Functions and Parameters: The Details

A function is called by using its name followed by a list of actual parametersor arguments1.<name>(<arguments>)

When Python comes to a function call, it initiates a four-step process.

1Rick will use the term arguments, John uses the term actual parameters

Page 16: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 16

Functions and Parameters: The Details

The calling program suspends execution at the point of the call.

The formal parameters of the function get assigned the values supplied by the actual parameters in the call.

The body of the function is executed.

Control returns to the point just after where the function was called.

Page 17: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 17

Functions and Parameters: The Details

Trace through the current program with a main method that tests maxOf3

Then move maxOf3 into another file named myFunctions.py

Leave the main method to test, but we need to now import that function

from myFunctions import maxOf3

Page 18: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 18

Functions and Paramters: The Details

One thing not addressed in this example was multiple parameters. In this case the formal and actual parameters are matched up based on position, e.g. the first actual parameter is assigned to the first formal parameter, the second actual parameter is assigned to the second formal parameter, etc.

Page 19: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 19

Getting Results from a Function

Passing parameters provides a mechanism for initializing the variables in a function.

Parameters act as inputs to a function.

We can call a function many times and get different results by changing its parameters.

Page 20: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 20

Functions That Return Values

We’ve already seen numerous

examples of functions that return values to the caller.discRt = math.sqrt(b*b – 4*a*c)

The value b*b – 4*a*c is the actual parameter of math.sqrt.

We say sqrt returns the square root of

its argument.

Page 21: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 21

Functions That Return Values

This function returns the square of a number:

def square(x):

return x*x

When Python encounters return, it exits the function and returns control to the point where the function was called.

In addition, the value(s) provided in the return statement are sent back to the caller as an expression result.

Page 22: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Python Programming, 2/e 22

Functions That Return Values

>>> square(3)

9

>>> print(square(4))

16

>>> x = 5

>>> y = square(x)

>>> print(y)

25

>>> print(square(x) + square(3))

34

Page 23: Python Programming: An Introduction to Computer Sciencemercer/ista130/... · Python Programming, 2/e 12 Functions and Parameters: The Details Each function is its own little subprogram

Consider CodingBats

http://codingbat.com/python

In class, write the answers to those shown

Python Programming, 2/e 23