百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

好程序员Python培训分享Python的递归函数与匿名函数调用

off999 2024-10-28 16:47 66 浏览 0 评论

  好程序员Python培训分享Python的递归函数与匿名函数调用,函数是Python技术学习中重要的一个环节,深入掌握该阶段的知识内容,对于Python技术能力的提升非常有帮助,这里就针对递归函数与匿名函数两种函数调用进行系统的介绍分析。

一. 递归函数

  a) 引言:在一个函数中自己调用自己会怎么样呢?会陷入无限的调用循环。为了解决该问题就需要使用递归。

  b) 应用:

  i. 案例分析:编写一个函数,该函数接收一个整数n,然后计算输出n的阶乘。

  1. 首先定义一个一个函数def factorial(n),该函数应该怎么实现呢?我们知道计算n的阶乘有如下规律:n!=n*[(n-1)*[n-2]…*1]=n*(n-1)!

  2. 函数实现步骤可以是:

  def factorial(n):

  1.计算(n-1)的阶乘

  2.返回step1的结果值*n

  要完成第一步的事情,就是要计算(n-1)!。由于我们这个函数是计算n!,因此第一步也可以理解为,以n-1为参数,调用factorial函数。代码就会变成:

  def factorial(n):

  1.factorial(n-1)

  2.返回step1的结果值*n

  在该代码中,出现了在factorial函数中调用factorial函数的情况。出现了函数的递归。为了完善上述代码,可以将代码中的第二部也翻译成代码:

  def factorial(n):

  1. int result=factorial(n-1)

  2. return result*n

  但是问题也出现了,加入n=3,在fac(3)的内部会调用fac(2),在fac(2)中会调用fac(1),在fac(1)中会调用fac(0)-》fac(-1)……因此我们需要规定一个循环调用结束的条件。在当前程序中当参数n的值为1时,则计算1的阶乘,到这一步就没有必要继续递归下去的必要了,因此n=1是,应当直接返回。

  def factorial(n):

  if(n==1):

  return 1

  int result=factorial(n-1)

  return result*n

二. 匿名函数

  a) 引言:当我们在创建函数的时,有的时候不需要显示的定义函数,直接传入匿名函数会更加的方便,这会省去我们挖空心思为函数命名的麻烦,也能少些不少的代码,很多编程语言都提供匿名函数这种特性。匿名函数用好了,会起到画龙点睛的效果,没用好就容易画虎不成反类犬,

  b) 在Python中使用lambda关键字来创建匿名函数。所谓匿名,即不再使用def这种标准形式定义函数,需要注意的有:

  i. lambda是一个表达式而不是一个代码块

  ii. 仅仅能在lambda表达式中封装有限的逻辑

  iii. Lambda函数拥有自己的命名空间

  c) 语法结构:lambda 参数:表达式 例如 lambda x:x*x, 冒号前的x表示的是参数,后面的表示函数的执行代码,,它相当于下面的函数:

  Def f(x): return x*x

  d) 注意:

  i. 匿名函数只能有一个表达式

  ii. 不用也不能写return语句,表达式的结果就是返回值

  iii. 匿名函数也是一个函数对象,可以将其赋值给一个变量,然后通过变量来调用该函数。f=lambda x:x*x f(6)

三. 推导式:是一种独特的推导式语法,可帮我们在某些场合写出比较精简炫酷的代码。但是没有它,也不会有太多的影响。

  a) 分类:

  i. 列表推导式

  ii. 字典推导式

  iii. 集合推导式

  iv. 元组推导式?

  b) 列表推导式:是一种快速生成列表的方式,其形式使用方括号括起来的一段语句。

  i. 案例:lis=[x*x for x in range(1,10) ] 首先执行for循环,对于每一个x带入x*x中进行运算,将运算的结果值逐一添加到一个新的列表内(x*x的式子中使用的变量必须为for中的x)。尤其可见,列表推导式为我们提供了一种在一行内实现较为复杂逻辑的生成列表的方法。其核心语法就是用中括号将生成的逻辑封装起来。

  ii. 案例:[x*x for x in range(1,11) if x%2==0] 通过增加if语句对x进行过滤

  iii. 案例:dic={“k1”:”v1”,”k2”:”v2”} a=[k+”:”+v for k,v in dic.items()]

  c) 字典推导式:列表推导式使用的是中括号,那么如果使用大括号则可以制造字典推导式

  i. 案例:dic={x:x*2 for x in(2,4,6)} x:x*2中间的冒号左边表示key右边表示value

  ii. 案例:也可以添加if子句

  d) 集合推导式:大括号除了可以用作字典推导式还可以用作集合推导式,注意两者差别。

  i. 案例:a={x for x in “abcdefg” if x not in “abc”}

  e) 元组推导式:那是用小括号的是不是元组推导式呢?no。在python中使用小括号的被叫做生成器的语法,在python中没有元组推导式。

  i. 如果想通过上述类似的方法生成元组,需要显示调用元组的类型转换函数tuple。t=tuple(x for x in range(10))

  f) 面试题:

  result = [lambda x: x + i for i in range(10)]

  print(result[0](10))

  答案是19,并且result[0~9](10)的结果都是19。这是因为函数具有调用时才查找变量的特性。在你没调用它之前,它不会保存也不关心它内部变量的具体值。只有等到你调用它的时候,它才逐一去找这些变量的具体值。这里的result[0]被调用的时候,变量i已经循环完毕,变成9了,而不是想象中的动态0-9值。

  那如果不想要这样的结果,想要i是循环的值怎么办?不要直接引用上层变量,把变量直接传进来。

  result = [lambda x, i=i: x + i for i in range(10)]

  print(result[0](10))

四. 迭代器

  a) 迭代:通过for循环遍历对象的每一个元素的过程。For可以遍历任何可迭代的对象。

  b) 可迭代对象类型:list/tuple/string/dict/set/bytes。可以通过collections模块的Iterable类型来判断一个对象是否可迭代:

  from collections import Iterable

  isinstance('abc', Iterable) # str是否可迭代

  c) 迭代器:是一种可以被遍历的对象。特点如下:

  i. 能调用next()函数。

  ii. 使用iter()函数创建迭代器对象

  iii. 迭代器对象从集合的第一个元素开始访问,直到所有元素被访问结束

  iv. 只能往后遍历,不能回溯

  v. 案例:

  >>> lis=[1,2,3,4]

  >>> it = iter(lis) # 使用Python内置的iter()方法创建迭代器对象

  >>> next(it) # 使用next()方法获取迭代器的下一个元素

  1

  >>> next(it)

  2

  >>> next(it)

  3

  >>> next(it)

  4

  >>> next(it) # 当后面没有元素可以next的时候,弹出错误

  或者使用for循环遍历迭代器:

  lis = [1,2,3,4]

  it = iter(lis) # 创建迭代器对象

  for x in it: # 使用for循环遍历迭代对象

  print (x, end=" ")

  迭代器的作用:除了可迭代的类型可以进行迭代外,在开发中也会遇到一些自定义的类型也有迭代的需求,即将自定义类型定义成迭代器类型即可(需要在类里实现__iter__()和__next__()方法,可供next和iter函数调用该对象)。for循环本质上就是通过不断调用next()函数实现的

  def iter(obj):

  return obj.__iter__()

  def next(obj):

  return obj.__next__()

  自定义迭代器类:

  import random

  class demo_iterator(object):

  def __next__(self):

  v = random.randint(0,10)

  if v < 5:

  raise StopIteration()

  else:

  return v

  def __iter__(self):

  return demo_iterator()

  迭代作用:可以把这个元素流看做是一个有序序列,但却不能提前知道序列的长度,只能不断通过next()函数得到下一个元素,所以迭代器可以节省内存和空间。

五. 生成器

  a) 引言:有时候,序列或集合内的元素的个数非常巨大,如果全制造出来并放入内存,对计算机的压力是非常大的。比如,假设需要获取一个10**20次方如此巨大的数据序列,把每一个数都生成出来,并放在一个内存的列表内,这是粗暴的方式,有如此大的内存么?如果元素可以按照某种算法推算出来,需要就计算到哪个,就可以在循环的过程中不断推算出后续的元素,而不必创建完整的元素集合,从而节省大量的空间。在Python中,这种一边循环一边计算出元素的机制,称为生成器:generator。

  b) 语法格式:类似推导式,使用小括号

  c) 案例:

  >>> g = (x * x for x in range(1, 4))

  >>> g

  at 0x1022ef630>

  可以通过next()函数获得generator的下一个返回值,这点和迭代器非常相似:

  >>> next(g)

  1

  但更多情况下,我们使用for循环。

  for i in g:

  print(i)

  d) 关键字yield:

  1. 用法:使用yield返回的函数会变成一个生成器。在调用生成器的过程中,每次遇到yield时,函数会暂停并保存当前所有的运行信息,返回yeild值。并在下一次运行next方法时从当前位置继续执行。

相关推荐

使用 python-fire 快速构建 CLI_如何搭建python项目架构

命令行应用程序是开发人员最好的朋友。想快速完成某事?只需敲击几下键盘,您就已经拥有了想要的东西。Python是许多开发人员在需要快速组合某些东西时选择的第一语言。但是我们拼凑起来的东西在大多数时候并...

Python 闭包:从底层逻辑到实战避坑,附安全防护指南

一、闭包到底是什么?你可以把闭包理解成一个"带记忆的函数"。它诞生时会悄悄记下自己周围的变量,哪怕跑到别的地方执行,这些"记忆"也不会丢失。就像有人出门时总会带上...

使用Python实现九九乘法表的打印_用python打印一个九九乘法表

任务要求九九乘法表的结构如下:1×1=11×2=22×2=41×3=32×3=63×3=9...1×9=92×9=18...9×9=81使用Python编写程序,按照上述格式打印出完整的九...

吊打面试官(四)--Java语法基础运算符一文全掌握

简介本文介绍了Java运算符相关知识,包含运算规则,运算符使用经验,特殊运算符注意事项等,全文5400字。熟悉了这些内容,在运算符这块就可以吊打面试官了。Java运算符的规则与特性1.贪心规则(Ma...

Python三目运算基础与进阶_python三目运算符判断三个变量

#头条创作挑战赛#Python中你学会了三步运算,你将会省去很多无用的代码,我接下来由基础到进阶的方式讲解Python三目运算基础在Python中,三目运算符也称为条件表达式。它可以通过一行代码实现条...

Python 中 必须掌握的 20 个核心函数——set()详解

set()是Python中用于创建集合的核心函数,集合是一种无序、不重复元素的容器,非常适合用于成员检测、去重和数学集合运算。一、set()的基本用法1.1创建空集合#创建空集合empty_se...

15个让Python编码效率翻倍的实用技巧

在软件开发领域,代码质量往往比代码数量更重要。本文整理的15个Python编码技巧,源自开发者在真实项目中验证过的工作方法,能够帮助您用更简洁的代码实现更清晰的逻辑。这些技巧覆盖基础语法优化到高级特性...

《Python从小白到入门》自学课程目录汇总(和猫妹学Python)

小朋友们好,大朋友们好!不知不觉,这套猫妹自学Python基础课程已经结束了,猫妹体会到了水滴石穿的力量。水一直向下滴,时间长了能把石头滴穿。只要坚持不懈,细微之力也能做出很难办的事。就比如咱们的学习...

8÷2(2+2) 等于1还是16?国外网友为这道小学数学题吵疯了……

近日,国外网友因为一道小学数学题在推特上争得热火朝天。事情的起因是一个推特网友@pjmdoll发布了一条推文,让他的关注者解答一道数学题:Viralmathequationshavebeen...

Python学不会来打我(21)python表达式知识点汇总

在Python中,表达式是由变量、运算符、函数调用等组合而成的语句,用于产生值或执行特定操作。以下是对Python中常见表达式的详细讲解:1.1算术表达式涉及数学运算的表达式。例如:a=5b...

Python运算符:数学助手,轻松拿咧

Python中的运算符就像是生活中的数学助手,帮助我们快速准确地完成这些计算。比如购物时计算总价、做家务时分配任务等。这篇文章就来详细聊聊Python中的各种运算符,并通过实际代码示例帮助你更好地理解...

Python学不会来打我(17)逻辑运算符的使用方法与使用场景

在Python编程中,逻辑运算符(LogicalOperators)是用于组合多个条件表达式的关键工具。它们可以将多个布尔表达式连接起来,形成更复杂的判断逻辑,并返回一个布尔值(True或Fa...

Python编程基础:运算符的优先级_python中的运算符优先级问题

多个运算符同时出现在一个表达式中时,先执行哪个,后执行哪个,这就涉及运算符的优先级。如数学表达式,有+、-、×、÷、()等,优先级顺序是()、×、÷、+、-,如5+(5-3)×4÷2,先计算(5-3)...

Python运算符与表达式_python中运算符&的功能

一、运算符分类总览1.Python运算符全景图2.运算符优先级表表1.3.1Python运算符优先级(从高到低)优先级运算符描述结合性1**指数右→左2~+-位非/一元加减右→左3*//...

Python操作Excel:从基础到高级的深度实践

Python凭借其丰富的库生态系统,已成为自动化处理Excel数据的强大工具。本文将深入探讨五个关键领域,通过实际代码示例展示如何利用Python进行高效的Excel操作,涵盖数据处理、格式控制、可视...

取消回复欢迎 发表评论: