Python-函数和代码复用
函数的定义与使用
>函数的理解与定义
函数是一段代码的表示
-函数是一段具有特定功能的、可重用的语句组
-函数是一种功能的抽象,一般函数表达特定功能
-两个作用:降低编程难度 和 代码复用
def <函数名>(<参数(0个或多个)>) :
<函数体>
return <返回值>
#计算n!
def fact(n) : #fact 函数名;n 参数
s = 1
for i in range(1, n+1):
s *= i
return s # s 返回值
-函数定义时,所指定的参数是一种占位符
-函数定义后,如果不经过调用,不会被执行
-函数定义时,参数是输入、函数体是处理、结果是输出(IPO)
>函数的使用及调用过程
调用是运行函数代码的方式
#接上段代码
a=fact(10)
-调用时要给出实际参数
-实际参数替换定义中的参数
-函数调用后得到返回值
>函数的参数传递
参数个数:函数可以有参数,也可以没有,但必须保留括号
def fact() :
print("我是一个没有参数的函数")
可选参数传递:函数定义时可以为某些参数指定默认值,构成可选参数
def <函数名>(<非可选参数>,<可选参数>) :
<函数体>
return <返回值>
#计算 n!//m
def fact(n, m=1) : #m=1为可选参数
s = 1
for i in range(1, n+1):
s *= i
return s//m
#fact(10) 3628800
#fact(10,5) 725760
可变参数传递
函数定义时可以设计可变数量参数,即不确定参数总数量
def <函数名>(<参数>,*b) :
<函数体>
return <返回值>
#计算 n!乘数
def fact(n, *b) : #*b可变参数
s = 1
for i in range(1, n+1):
s *= i
for item in b:
s *= item
return s
# fact(10,3) 10886400
#fact(10,3,5,8) 435456000
参数传递的两种方式:函数调用时,参数可以按照位置或名称方式传递
def fact(n, m=1) :
s = 1
for i in range(1, n+1):
s *= i
return s//m
# fact( 10,5 ) 725760
# fact( m=5,n=10 ) 725760
>函数的返回值
函数可以返回0个或多个结果
-return保留字用来传递返回值
-函数可以有返回值,也可以没有,可以有return,也可以没有
-return可以传递0个返回值,也可以传递任意多个返回值
def fact(n,m=1):
s=1
for i in range(1,n+1)
s*=i
return s//m,n,m
#fact(10,5) (725760,10,5)
#a,b,c=fact(10,5)
#print(a,b,c)
#725760 10 5
>局部变量与全局变量
n, s = 10, 100 #n,s时全局变量
def fact(n) :
s = 1 #fact()函数中的n s是局部变量
for i in range(1, n+1):
s *= i
return s
print(fact(n), s) #n,s是全局变量
#3628800 100
规则1:局部变量和全局变量是不同变量
-局部变量是函数内部的占位符,与全局变量可能重名但不同
-函数运算结束后,局部变量被释放
-可以使用global保留字在函数内部使用使用全局变量
n, s = 10, 100 #n,s时全局变量
def fact(n) :
global s #fact()函数中使用global保留字声明 此处s是全局变量s
for i in range(1, n+1):
s *= i
return s
print(fact(n), s) #此处全局变量s是被函数修改
#362880000 362880000
规则2:局部变量为组合数据类型且未创建,等同于全局变量
ls = ["F", "f"] #通过使用[]真实创建了一个全局变量列表ls
def func(a) :
ls.append(a) #此处ls是列表类型,未真实创建 则等同于全局变量
return
func("C") #局部变量ls被修改
print(ls)
# ['F','f','C']
ls = ["F", "f"] #通过使用[]真实创建了一个全局变量列表ls
def func(a) :
ls = [] #此处ls是列表类型,真实创建ls是局部变量
ls.append(a)
return
func("C") #局部变量ls被修改
print(ls)
#['F','f']
使用规则
-基本数据类型,无论是否重名,局部变量与全局变量不同
-可以通过global保留字在函数内部声明全局变量
-组合数据类型,如果局部变量未真实创建,则是全局变量
>lambda函数
lambda函数返回函数名作为结果
-lambda函数是一种匿名函数,即没有名字的函数
-使用lambda保留字定义,函数名是返回结果
-lambda函数用于定义简单的、能够在一行内表示的函数
<函数名> = lambda <参数> : <表达式>
等价于
def <函数名> (<参数>):
<函数体>
return <返回值>
f=lambda x,y:x+y
f=(10,15)
#结果:25
f=lambda:"lambda函数"
print(f())
#结果:lambda函数
谨慎使用lambda函数
-lambda函数主要用作一些特定函数或方法的参数
-lambda函数有一些固定的使用方式,建议逐步掌握
-一般情况,建议使用def定义的普通函数
代码复用与函数递归
>代码复用与模块化设计
把代码当成资源的抽象
-代码资源化:程序代码是一种用来表达计算的“资源”
-代码抽象化:使用函数等方法对代码赋予更高级别的定义
-代码复用:同一份代码在需要时可以被重复使用
函数 和 对象 是代码复用的两种主要形式
函数:将代码命名在代码层面建立了初步抽象
对象:属性和方法 <a>.<b> 和<a>.<b>( )在函数之上再次组织进行抽象
分而治之
-通过函数或对象封装将程序划分为 模块及 模块间的表达
-具体包括:主程序、子程序和子程序间的关系
-分而治之:一种分而治之、分层抽象、体系化的设计思想
紧耦合 松耦合
-紧耦合:两个部分之间交流很多,无法独立存在
-松耦合:两个部分之间交流少,可以独立存在
-模块内部紧耦合、模块之间松耦合
>函数递归的理解
函数定义中调用函数自身的方式

两个关键特征
-链条:计算过程存在递归链条
-基例:存在一个或多个不需要再次递归的基例
类似数学归纳法
-数学归纳法
-证明当n取第一个值n0时命题成立
-假设当nk时命题成立,证明当n=nk+1时命题也成立
-递归是数学归纳法思维的编程体现
>函数递归的调用过程

def fact(n):
if n==0:
return 1
else:
return n*fact*(n-1)
函数+分支语句
-递归函数本身是一个函数,需要函数定义方式描述
-函数内部,采用分支语句对输入参数进行判断
-基例和链条,分别编写对应代码

>函数递归实例解析
将字符串s反转后输出
def rvs(s):
if s == "":
return s
slse:
return rvs(s[1:])+s[0]
斐波那契数列:一个经典的数列

def f(n):
if n==1 or n==2 :
return 1
else:
return f(n-1)+f(n-2)
Python-函数和代码复用的更多相关文章
- Python基础篇(三)_函数及代码复用
Python基础篇_函数及代码复用 函数的定义.使用: 函数的定义:通过保留字def实现. 定义形式:def <函数名>(<参数列表>): <函数体> return ...
- 函数和代码复用 --Python
1.关于递归函数的描述,以下选项中正确的是 A.包含一个循环结构 B.函数比较复杂 C.函数内部包含对本函数的再次调用 D.函数名称作为返回值 答案:D 答案解析:递归函数是指函数内部包含对本函数的再 ...
- Python学习笔记(五)函数和代码复用
函数能提高应用的模块性,和代码的重复利用率.在很多高级语言中,都可以使用函数实现多种功能.在之前的学习中,相信你已经知道Python提供了许多内建函数,比如print().同样,你也可以自己创建函数, ...
- Python__函数和代码复用
主要内容 函数的定义和使用 实例:七段数码管的绘制 代码复用与函数递归 PyInstall库的使用 实例:科赫雪花小包裹 函数的定义与使用 函数的理解与定义 函数的使用及调用过程 函数的参数传递 函数 ...
- Python学习笔记6函数和代码复用
1.函数 (1)定义: (2)函数调用 (3)函数的参数传递 参数传递的两种方式:函数调用时,参数可以按照位置或名称的方式传递 (4)函数的返回值 (5)局部变量和全局变量 (6)lambda函数 2 ...
- Python语言程序设计基础(5)—— 函数和代码复用
lambda sum = lambda x,y : x + y print(sum(3,3),type(sum)) 默认参数 def prints(str,times = 2) : print(str ...
- Python中用函数实现代码的复用
# Python中用函数实现代码复用 """ def funcname(paras): statements return [expression] 关于函数定义说明如下 ...
- 10分钟学会Python函数基础知识
看完本文大概需要8分钟,看完后,仔细看下代码,认真回一下,函数基本知识就OK了.最好还是把代码敲一下. 一.函数基础 简单地说,一个函数就是一组Python语句的组合,它们可以在程序中运行一次或多次运 ...
- if __name__== "__main__" 的意思(作用)python代码复用
if __name__== "__main__" 的意思(作用)python代码复用 转自:大步's Blog http://www.dabu.info/if-__-name__ ...
随机推荐
- go语言---for range
学习-go语言坑之for range https://www.cnblogs.com/hetonghai/p/6718250.html go只提供了一种循环方式,即for循环,在使用时可以像c那样使用 ...
- 【POI 2010】 Pilots
[题目链接] 点击打开链接 [算法] 单调队列 [代码] #include<bits/stdc++.h> using namespace std; #define MAXN 3000010 ...
- [USACO15DEC]High Card Low Card (Platinum)
https://www.zybuluo.com/ysner/note/1300791 题面 贝西和她的朋友艾尔西正在玩这个简单的纸牌游戏.游戏有\(2N\)张牌,牌上的数字是\(1\)到\(2N\). ...
- 查看mysql数据库的所有配置信息和服务器的各种状态
查看MySQL服务器配置信息 mysql> show variables; 2, 查看MySQL服务器运行的各种状态值 mysql> show global status;
- Maximum Gap 典型线性排序
https://leetcode.com/problems/maximum-gap/ Given an unsorted array, find the maximum difference betw ...
- ASP.Net 知识点总结(三)
1.描述一下C#中索引器的实现过程,是否只能根据数字进行索引? 答:不是.可以用任意类型. 2.<%# %> 和 <% %> 有什么区别? 答:<%# %>表示绑定 ...
- CF17C Balance
题意 [题目描述] 一个仅由a,b,c三种字符组成的字符串,可以对其进行如下两种操作: 选择两个相邻字符,将第一个字符替换成第二个. 选择两个相邻字符,将第二个字符替换成第一个. 这样,通过任意多次的 ...
- 51nod2006 飞行员配对(二分图最大匹配)
2006 飞行员配对(二分图最大匹配) 题目来源: 网络流24题 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 第二次世界大战时期,英国皇家空军从沦陷国 ...
- LPS HDOJ 4745 Two Rabbits
题目传送门 /* 题意:一只兔子顺时针跳,另一只逆时针跳,跳石头权值相等而且不能越过起点 LPS:这道就是LPS的应用,把环倍增成链,套一下LPS,然而并不能理解dp[i][i+n-2] + 1,看别 ...
- ORA-01654_TableSpace空间不足问题处理
操作环境:Windows Server 2008 R2,32位Oracle11g R2. 导入大批量数据时报如下错误信息: ORA-: 索引IOT.IDX_IOT_EQUIP_ID无法通过1024(在 ...