建站专家网站建设系统/深圳网站开发技术

建站专家网站建设系统,深圳网站开发技术,公众号做网站,网站建设制作设计营销 广州目录 闭包 什么是闭包: 闭包的基本结构: 实现闭包的条件: 1.嵌套函数 2.内函数引用外部函数的变量 3.外部函数返回内部函数 4.外部函数已经执行完毕 递归函数 什么是递归函数: 递归函数条件 1.必须有个明确的结束条…


 

目录

 

闭包

什么是闭包:

闭包的基本结构:

实现闭包的条件:

1.嵌套函数 

2.内函数引用外部函数的变量 

3.外部函数返回内部函数 

4.外部函数已经执行完毕 

递归函数

什么是递归函数:

递归函数条件

1.必须有个明确的结束条件  ———递归出口

2.每进行更深一步的递归,问题规模相比上一次递归都要有所减少

3.相邻两次重复之间有紧密联系

分析一下这段代码

1.函数定义:

2. 基准条件(Base Case)

3. 递归条件(Recursive Case)

典型的递归函数的例子

1到100的相加

 2.斐波那契数列

递归的优缺点

优点

缺点 

递归的应用场景 

递归的注意事项 


闭包

什么是闭包:

闭包是指在一个函数内部定义的函数,并且这个内部函数引用了外部函数的变量。即使外部函数已经执行完毕,内部函数仍然可以访问和操作这些变量

闭包的基本结构:

def outer_function(x):def inner_function(y):return x + yreturn inner_functionclosure = outer_function(10)
print(closure(5))  # 输出 15

接下来我为大家解释一下这段代码:

  • outer_function 是外部函数,它接受一个参数 x

  • inner_function 是内部函数,它接受一个参数 y,并且引用了外部函数的变量 x

  • outer_function 返回 inner_function,而不是调用它。

  • 当我们调用 outer_function(10) 时,它返回 inner_function,并且 x 被设置为 10

  • 然后我们调用 closure(5),实际上是在调用 inner_function(5),此时 x 仍然是 10,所以结果是 15

实现闭包的条件:

1.嵌套函数 

闭包必须在一个外部函数中定义一个内部函数。也就是说,函数内部再定义一个函数。

def outer_function():def inner_function():passreturn inner_function

2.内函数引用外部函数的变量 

内部函数必须引用外部函数的变量(即自由变量)。这是闭包的核心,内部函数通过引用外部函数的变量来“记住”外部函数的环境。

def outer_function(x):def inner_function(y):return x + y  # 内部函数引用了外部函数的变量 xreturn inner_function

3.外部函数返回内部函数 

外部函数必须返回内部函数(而不是调用它)。这样,内部函数可以在外部函数执行完毕后继续存在,并且仍然可以访问外部函数的变量。

def outer_function(x):def inner_function(y):return x + yreturn inner_function  # 返回内部函数,而不是调用它closure = outer_function(10)
print(closure(5))  # 输出 15

4.外部函数已经执行完毕 

闭包的特性在于,即使外部函数已经执行完毕,内部函数仍然可以访问外部函数的变量。这是因为闭包将外部函数的变量“捕获”并保存在内部函数的环境中。

def outer_function(x):def inner_function(y):return x + yreturn inner_functionclosure = outer_function(10)  # 外部函数执行完毕,x 被设置为 10
print(closure(5))  # 内部函数仍然可以访问 x,输出 15

总结一下:

  1. 嵌套函数:在一个函数内部定义另一个函数。

  2. 内部函数引用外部函数的变量:内部函数必须引用外部函数的变量。

  3. 外部函数返回内部函数:外部函数返回内部函数,而不是调用它。

  4. 外部函数已经执行完毕:即使外部函数执行完毕,内部函数仍然可以访问外部函数的变量。

这些条件共同作用,使得闭包能够“记住”其定义时的环境,并在后续调用中继续使用这些环境中的变量。 


递归函数

什么是递归函数:

递归函数(Recursive Function)是指在函数的定义中调用函数自身的函数。递归是一种强大的编程技术,特别适用于解决可以分解为相似子问题的问题。理解递归的概念和应用场景,可以帮助你编写更加简洁和优雅的代码。

递归函数条件

1.必须有个明确的结束条件  ———递归出口

2.每进行更深一步的递归,问题规模相比上一次递归都要有所减少

3.相邻两次重复之间有紧密联系

递归的基本结构

def recursive_function(parameters):if base_case_condition(parameters):  # 基准条件return base_case_valueelse:# 递归条件return recursive_function(modified_parameters)

 

分析一下这段代码
1.函数定义:
  • recursive_function 是一个递归函数,它接受一个或多个参数 parameters

  • 参数 parameters 是递归函数的输入,通常用于表示当前问题的状态或规模。


    2. 基准条件(Base Case)
  • if base_case_condition(parameters):

    • 这是递归的终止条件。

    • base_case_condition(parameters) 是一个判断条件,用于检查当前参数是否满足递归终止的条件。

    • 如果满足基准条件,函数直接返回 base_case_value,不再进行递归调用。

    • 基准条件的作用:防止无限递归,确保递归最终能够终止。

 

示例: 

 在这个例子中,n == 0 是基准条件,当 n 为 0 时,递归停止,函数返回 1


3. 递归条件(Recursive Case)
  • else:

    • 如果基准条件不满足,函数进入递归条件。

    • 在递归条件中,函数会调用自身(即 recursive_function),但传入的参数会被修改(modified_parameters)。

    • 修改参数的目的是将问题规模缩小,逐步逼近基准条件。

      def factorial(n):if n == 0:  # 基准条件return 1else:  # 递归条件return n * factorial(n - 1)

      在这个例子中,factorial(n - 1) 是递归调用,每次递归调用时,n 的值都会减小,逐步逼近基准条件 n == 0

典型的递归函数的例子

1.

1到100的相加

(一般方法)

# def add():
#     s=0
#     for i in range(1,101):
#         s +=i
#     print(s)
# add()

采用递归

# def add(n):
#     if n ==1:
#         return 1
#
#     return n +add(n-1)
# print(add(100))

 2.斐波那契数列

def fibonacci(n):if n == 0:  # 基准条件return 0elif n == 1:  # 基准条件return 1else:return fibonacci(n - 1) + fibonacci(n - 2)  # 递归条件print(fibonacci(10))  # 输出 55

这个例子中:

  • 当 n 为 0 或 1 时,函数返回相应的基准值。

  • 否则,函数返回 fibonacci(n - 1) + fibonacci(n - 2),即前两个斐波那契数的和。

递归的优缺点

优点

  1. 简洁性:递归代码通常比迭代代码更简洁和易读。

  2. 自然表达:对于某些问题(如树遍历、分治算法等),递归提供了一种自然的表达方式

缺点 

 

  1. 性能问题:递归可能会导致大量的函数调用,增加栈的深度,从而影响性能。

  2. 栈溢出:如果递归深度过大,可能会导致栈溢出错误。

  3. 重复计算:在某些情况下(如斐波那契数列的简单递归实现),递归可能会导致大量的重复计算。

递归的应用场景 

  1. 树和图的遍历:递归非常适合用于树和图的遍历(如深度优先搜索)。

  2. 分治算法:许多分治算法(如归并排序、快速排序)都使用递归来分解问题。

  3. 动态规划:递归常用于动态规划问题的初始实现,然后可以通过记忆化或迭代来优化。

递归的注意事项 

  1. 确保基准条件正确:基准条件是递归终止的关键,必须确保它能够正确终止递归。

  2. 避免无限递归:如果递归条件没有正确地向基准条件靠近,可能会导致无限递归,最终导致栈溢出。

  3. 考虑性能问题:对于性能敏感的应用,可能需要将递归转换为迭代,或使用记忆化来优化递归。

总结一下: 递归函数是一种强大的编程工具,特别适用于解决可以分解为相似子问题的问题。理解递归的基本概念、优缺点和应用场景,可以帮助你编写更加简洁和优雅的代码。然而,递归也需要谨慎使用,特别是在性能敏感的应用中

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

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

相关文章

ABAP PDF预览

画个屏幕 PDF JPG TXT都可以参考预览,把二进制流传递给标准函数就行 *&---------------------------------------------------------------------* *& Report YDEMO2 *&---------------------------------------------------------------------* *&am…

【视频】文本挖掘专题:Python、R用LSTM情感语义分析实例合集|上市银行年报、微博评论、红楼梦、汽车口碑数据采集词云可视化

原文链接:https://tecdat.cn/?p41149 分析师:Zhenzhen Liu,Shuai Fung 作为数据科学家,我们始终关注如何从非结构化数据中提取高价值信息。本专题合集聚焦企业年报的文本分析技术,通过Python与R语言实战案例&#xff…

高效团队开发的工具与方法 引言

引言 在现代软件开发领域,团队协作的效率和质量直接决定了项目的成败。随着项目规模的扩大和技术复杂度的增加,如何实现高效团队开发成为每个开发团队必须面对的挑战。高效团队开发不仅仅是个人技术能力的简单叠加,更需要借助合适的工具和方…

Python----计算机视觉处理(Opencv:图像颜色替换)

一、开运算 开运算就是对图像先进行腐蚀操作, 然后进行膨胀操作。开运算可以去除二值化图中的小的噪点,并分离相连的物体。 其主要目的就是消除那些小白点 在开运算组件中,有一个叫做kernel的参数,指的是核的大小,通常…

基于SpringBoot的“ERP-物资管理”的设计与实现(源码+数据库+文档+PPT)

基于SpringBoot的“ERP-物资管理”的设计与实现(源码数据库文档PPT) 开发语言:Java 数据库:MySQL 技术:SpringBoot 工具:IDEA/Ecilpse、Navicat、Maven 系统展示 系统总体结构图 E-R实体关系图 管理员登录界面 管…

链表操作:分区与回文判断

目录 链表分区(Partition) 功能概述 代码实现 要点与难点 注意事项 链表回文判断(PalindromeList) 功能概述 代码实现 要点与难点 注意事项 总结 在链表相关的算法问题中,理解链表的基本结构和操作至关重要…

如何在 Node.js 中使用 .env 文件管理环境变量 ?

Node.js 应用程序通常依赖于环境变量来管理敏感信息或配置设置。.env 文件已经成为一种流行的本地管理这些变量的方法,而无需在代码存储库中公开它们。本文将探讨 .env 文件为什么重要,以及如何在 Node.js 应用程序中有效的使用它。 为什么使用 .env 文…

【Git学习笔记】Git结构原理及其分支管理模型分析

【Git学习笔记】Git结构原理及其分支管理模型分析 🔥个人主页:大白的编程日记 🔥专栏:Git学习笔记 文章目录 【Git学习笔记】Git结构原理及其分支管理模型分析前言一.认识工作区、暂存区、版本库1.1 版本回退1.2 撤销修改1.3 删…

[特殊字符]Windows 11 安装 Git 图文教程(含详细配置说明)

Windows 11 安装 Git 图文教程(含详细配置说明) 本教程适用于 Git 新手,手把手教你如何在 Windows 11 上完整安装 Git 并正确配置,配图清晰,步骤明确,建议收藏! ✅ 第一步:下载 Git 安装包 访问官网:https://git-scm.com自动识别系统后点击下载或者直接前往:Git for …

简单以太网配置

display arp //查看路由器mac地址 交换机配置命令: system-view // 从用户视图进入系统视图 dis mac-address //查看mac地址表 路由器配置命令: system-view // 从用户视图进入系统视图 int GigabitEthernet 0/0/0 //进入G口 0/0/0 进入之后配置网关: ip addre…

配置集群-日志聚集操作

1.修改配置文件 <!-- 开启日志聚集功能 --> <property> <name>yarn.log-aggregation-enable</name> <value>true</value> </property> <!-- 设置日志聚集服务器地址 --> <property> <name>yarn.log.server.url&…

华为ipd流程华为流程体系管理华为数字化转型流程数字化管理解决方案介绍81页精品PPT

华为流程体系最佳实践主要包括构建完善的流程框架&#xff0c;明确各层级流程要素与职责&#xff0c;梳理涵盖研发、采购、营销、服务、资产管理等多领域的流程&#xff0c;通过梳理业务场景和核心能力搭建差异化流程框架&#xff0c;采用自上而下与自下而上相结合的建模方法&a…

在 Spring Boot 中调用 AnythingLLM 的发消息接口

整体逻辑: 自建系统的web UI界面调用接口: 1.SpringBoot接口&#xff1a;/anything/chatMessageAnything 2.调用anythingLLM - 调用知识库deepseek r1 . Windows Installation ~ AnythingLLMhttps://docs.anythingllm.com/installation-desktop/windows http://localhost:3…

Python生成和安装requirements.txt

概述 看到别的大佬项目中&#xff0c;requirements.txt文件&#xff0c;里面包含了所需要的依赖及版本&#xff0c;方便项目管理和安装。 生成 requirements.txt 文件 pip3 freeze > requirements.txt生成的依赖包有点多&#xff0c;感觉可以根据自己需要整理。 安装req…

零知识证明:区块链隐私保护的变革力量

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;https://literature.sinhy.com/#/literature?__c1000&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;…

★ Linux ★ 进程(上)

Ciallo&#xff5e;(∠・ω< )⌒☆ ~ 今天&#xff0c;我将和大家一起学习 linux 进程~ ​❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️❄️ 澄岚主页&#xff1a;椎名澄嵐-CSDN博客 Linux专栏&#xff1a;https://blog.csdn.net/2302_80328146/category_12815302…

Java面试第十一山!《SpringCloud框架》

大家好&#xff0c;我是陈一。如果文章对你有帮助&#xff0c;请留下一个宝贵的三连哦&#xff5e; 万分感谢&#xff01; 目录 一、Spring Cloud 是什么​ 二、Spring Cloud 核心组件​ 1. 服务发现 - Eureka​ 2. ​负载均衡 - Ribbon​ 3. 断路器 - Hystrix​ ​​4. …

Spring配置文件-Bean实例化三种方式

无参构造方法实例化 工厂静态方法实例化 工厂实例方法实例化

SpringBoot学习(三)SpringBoot整合JSP以及Themeleaf

目录 Spring Boot 整合 JSP1. 配置依赖2. 创建WEB目录结构&#xff0c;配置JSP解析路径3. 创建Controller类4. 修改application.yml5. 添加jstl标签库的依赖6. JSP页面7. 创建启动类 Spring Boot 整合 Thymeleaf1. 添加Thymeleaf依赖2. Controller3. 修改application.yml配置&a…

普通鼠标的500连击的工具来了!!!

今天介绍的这款软件叫&#xff1a;鼠标录制器&#xff0c;是一款大小只有54K的鼠标连点器&#xff0c;软件是绿色单文件版。抢票&#xff0c;拍牌&#xff0c;摇号都能用上。文末有分享链接 在使用先我们先设置快捷键&#xff0c;这样我们在录制和停止录制的时候会更方便。 软件…