函数基础与递归

        函数是一系列常被重复使用的语句被抽取成一个"集合体",每次调用这个函数就相当于调用了这些语句,这样总体的代码函数会大幅降低。

例1:打印列表各元素值

a = list("python")
i = 0
while i < len(a):
    print a[i]
    i = i + 1
b = [1, 3, 4, 6]
i = 0
while i < len(b):
    print b[i]
    i = i + 1
c = range(1, 11)
i = 0
while i < len(c):
    print c[i]
    i = i + 1

 

从上边的例子可以看出,程序主要有3个列表a、b、c并打印了这三个列表里的数据,但代码行数较多,也不利于对程序的理解,其实可以将

i = 0
while i < len():
    print
    i = i + 1

 

抽象成函数printList,实际使用printList函数时是针对每个不同的列表来使用的,每次都打印不同的列表,那么每次打印的内容,可以作为printList函数的参数,传给printList函数,传入的不同内容即实现打印不同的内容,因此函数既有要做的事情即函数体(语句块),还要有处理对象(参数)。

1 定义函数

自定义定义函数的语法格式:

def 函数名(参数列表):
    语句块

 

需要注意作为函数的语句,前需要按Tab键进行缩进对齐,没有按Tab缩进对齐的语句不属于该函数。

例2:printList函数的实现

def printList(x):
    i = 0
    while i < len(x):
        print x[i]
        i = i + 1

 

在定义好了函数之后,原来的“例1”的程序可以改成如下的样子。

#coding:utf-8
# 定义函数printList、x为参数(形参)
def printList(x):
    i = 0
    while i < len(x):
        print x[i]
        i = i + 1
a = list("python")
# 函数printList的调用,a为实参
printList(a)
b = [1, 3, 4, 6]
printList(b)
c = range(1, 11)
printList(c)

 

这样的程序及结构是不是清晰一些了呢?

2 全局和局部变量

函数体里的变量是局部的,可以在函数内部使用,而函数体外部的变量是全局的,可以在函数体内部访问(读),但如果想在函数内部修改全局变量得先用global声明一下要修改的全局变量。

x = 12
def m():
    global x
    x = 13
print x
m()
print x

 

如果函数里没有对某变量global进行声明就修改全局变量的值,程序会视为函数有和全局变量同名的局部变量,那么同名的全局变量对本函数不可见。

x = 12
def m():
    #global x
    x = 13
    print x
m()
print x

 

3 递归

递归,函数定义里使用了函数本身。一般会使用if_else结构控制递归的进入和退出。

例3:求n!(n的阶乘)

用递归很容易,求解n!的数学过程如下所示,需要注意的是0!和1!都为1。

s0 = 1
s1 = 1 * s0
s2 = 2 * s1 = 2 * 1
s3 = 3 * s2 = 3 * 2 * 1
....
sn = n * s(n-1) = n * (n - 1) * .... * 2 * 1

 

可以用while循环来实现。

def Factorial(x):
    i = 1
    s = 1
    while i <= x:
        s = i * s
        i = i + 1
    return s
print Factorial(5)

 

也可以用递归来实现。

def Factorial(x):
    if x == 0: # 终止、退出
        return 1
    else:
        return x * Factorial(x - 1) #递归进入
print Factorial(3)

 

例4:利用递归实现正序打印列表

s = "python"
def printS(x, index):
    if index < len(s):
        print x[index],
        printS(x, index + 1)

printS(s, 0)

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/177297.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

掌握Java的核心概念与技术

问题&#xff1a;请说明什么是解释器模式&#xff0c;并使用Java代码举例说明其使用场景和实现方式。 答案&#xff1a; 解释器模式是一种行为型设计模式&#xff0c;它定义了一种语言的文法&#xff0c;并且通过解释器来解释执行这个语言中的表达式。解释器模式将一个复杂的…

进程(4)——进程地址空间【linux】

进程&#xff08;4&#xff09;——进程地址空间【linux】 一.什么是进程地址空间二.进程地址空间不是真实地址&#xff1f;三.物理地址与进程地址空间的关系&#xff08;整体部分&#xff09;四. 细节4.1 进程地址空间的本质&#xff1a;4.2 为什么要有进程地址空间&#xff1…

Mac 搭建本地服务器

文章目录 1 启动服务器2 服务器目录3 手机访问服务器3.1 手机和电脑连上同一个局域网( 或WIFI)3.2 找到电脑的ip地址 如下图所示3.3 手机打开 http://192.168.10.5/1.txt 4 关闭服务器5 参考文章 1 启动服务器 sudo apachectl start启动后访问 http://localhost/ 如下图所示即…

JavaWeb后端数据库MySQL的使用

JavaWeb MySQLSQL数据库设计 多表设计1对多1对1多对多 多表查询连接查询内连接外连接左外连接右外连接 子查询事务索引 MySQL MySQL数据模型 关系型数据库&#xff1a;建立在关系模型基础上&#xff0c;由多张相互连接的二维表组成的数据库。 SQL SQL&#xff1a;操作关系型数…

系列二十一、Spring中bean的创建顺序

一、概述 我们知道启动IOC容器时&#xff0c;Spring会为我们创建各种各样的bean&#xff0c;那么思考一个问题&#xff0c;bean的创建顺序是由什么决定的呢&#xff1f;答&#xff1a;bean的创建顺序是由BeanDefinition的注册信息决定的&#xff0c;这个其实很好理解&#xff0…

创建SpringBoot Helloword 程序详细步骤

本文档实现SpringBoot hello word 程序&#xff0c;翻译于Spring | Quickstart 目录 一、项目创建步骤1.1 创建项目1.2 添加代码1.3 运行 参考教程 一、项目创建步骤 1.1 创建项目 在官网Spring Initializr上创建项目 1.2 添加代码 在IDE中打开项目并在src/main/java/com/zo…

pinpoint链路跟踪运用及日志logback配置

本文将讲述pinpoint的安装&#xff0c;使用及与java logback 日志的集成。 介绍 是什么 是一款 APM监控工具(Application Performance Management/应用性能管理)基于java编写用于 大规模分布式系统 的监控&#xff0c;是 分析 大规模分布式系统 的平台基于google Dapper开发&…

springMVC,什么是Spring MVC? Spring MVC的主要组件? springMVC工作原理/流程 MVC框架

文章目录 springMVC什么是Spring MVC&#xff1f;Spring MVC的主要组件&#xff1f;springMVC工作原理/流程MVC框架 今天以这篇文章简单和大家聊聊springMVC相关的内容&#xff0c;和原理&#xff0c;以及框架&#xff1b; springMVC 什么是Spring MVC&#xff1f; Spring MV…

Android Bitmap 模糊效果实现 (二)

文章目录 Android Bitmap 模糊效果实现 (二)使用 Vukan 模糊使用 RenderEffect 模糊使用 GLSL 模糊RS、Vukan、RenderEffect、GLSL 效率对比 Android Bitmap 模糊效果实现 (二) 本文首发地址 https://blog.csdn.net/CSqingchen/article/details/134656140 最新更新地址 https:/…

Android中给一个TextView设置不同样式

在开发中有时候需要给同一个TextView设置不同样式&#xff0c;比如修改某些字体颜色、字体大小、粗体、斜体等&#xff0c;再比如在文字中加一些图标等&#xff1b; 1.Html.fromHtml 在Android中是支持Html标签的使用的&#xff0c;但并不是所有的HTML标签都支持。 HTML基础…

2021年03月 Scratch图形化(四级)真题解析#中国电子学会#全国青少年软件编程等级考试

Scratch等级考试(1~4级)全部真题・点这里 一、单选题(共15题,每题2分,共30分) 第1题 运行如下图所示的程序后,以下描述正确的是? A:角色停留在(0,0)的位置,不会移动。 B:角色会在舞台上沿水平方向不停地左右往返移动,碰到边缘就反弹。 C:角色会向右沿水平方向…

【MVP矩阵】裁剪空间、NDC空间、屏幕空间

裁剪空间概述 裁剪空间是一个顶点乘以MVP矩阵之后所在的空间&#xff0c;Vertex Shader的输出就是在裁剪空间上&#xff08;划重点&#xff09; NDC空间概述 接上面&#xff0c;由GPU自己做透视除法将顶点转到NDC空间 两者的转换 透视除法将Clip Space顶点的4个分量都除以…

C语言SO EASY(ZZULIOJ1220: SO EASY)

题目描述 Superbin最近在研究初等数论&#xff0c;初等数论 是研究数的规律&#xff0c;特别是整数性质的数学分支。它是数论的一个最古老的分支。它以算术方法为主要研究方法&#xff0c;主要内容有整数的整除理论、同余理论、连分数理论和某些特殊不定方程。 是定义在正整数…

linux设置主机名

查看主机名&#xff1a;hostname 临时修改主机名&#xff1a;hostname 新主机名 [rootlocalhost ~]#hostname centos [rootlocalhost ~]#hostname centos 永久修改主机名&#xff1a; [rootlocalhost ~]#cat /etc/hostname localhost.localdomain

C#Backgroundworker与Thread的区别

前言 当谈到多线程编程时&#xff0c;C#中的BackgroundWorker和Thread是两个常见的选择。它们都可以用于实现并行处理和异步操作&#xff0c;但在某些方面有一些重要的区别。本文将详细解释BackgroundWorker和Thread之间的区别以及它们在不同场景中的使用。 目录 前言1. Backgr…

barcode.js+elementUi——实现二维码的展示——基础积累

barcode.js——实现二维码的展示——基础积累 CSDN服务器一直报错条形码需求分析1.barcode.js的引入2.html页面上的写法——我这边是一个elementUI的弹窗条形码3.script中的部分 CSDN服务器一直报错 最近不知道怎么了&#xff0c;CSDN一直报服务器错误&#xff0c;不能只有我自…

Web应用与http协议

Web应用 一 Web应用程序是什么 Web应用程序是一种可以通过Web访问的应用程序&#xff0c;程序的最大好处是用户很容易访问应用程序&#xff0c;用户只需要有浏览器即可&#xff0c;不需要再安装其他软件 应用程序有两种模式C/S、B/S。C/S是客户端/服务器端程序&#xff0c;也…

自动驾驶视觉感知技术

1、视觉感知 2、应用功能 3、视觉感知支持的功能 4、软硬件产品 5、DMS、手势识别、行为检测 6、DMS视觉检测 7、驾驶员离位检测 8、安全带检测 9、双手脱离方向盘检测 10、后排遗留物检测 11、360环视AVM倒车指引线MOD 12、盲区监测

STM32算法

1.通过编码器对返回的错误速度进行滤波 #define MOTOR_BUFF_CIRCLE_SIZE 4 #define STATIC_ENCODER_VALUE 6int32_t LMotor_Encoder_buff[MOTOR_BUFF_CIRCLE_SIZE] {0}; uint8_t LEindex 0; int32_t LMotor_Encoder_last 0; int32_t L_Encoder_change 0;int32_t RMotor_…

上门预约互联网干洗店洗鞋店小程序开发

很多时候可能大家的衣服鞋子需要干洗&#xff0c;但又不想出门送去店里&#xff0c;大家就可以使用手机线上下单预约取货&#xff0c;会有专门的人上门来取衣服&#xff0c;让你能够轻松的进行洗护。 闪站侠洗衣洗鞋小程序&#xff0c;提供了足不出户就能预约人员上门去 衣送洗…