python 基础知识点(蓝桥杯python科目个人复习计划27)

今日复习内容:基础算法中的递归

1.介绍

  • 递归:通过自我调用来解决问题的函数
  • 递归通常把一个复杂的大问题层层转化为一个与原问题相似的规模较小的问题来解决 
  • 递归要注意:(1)递归出口;(2)当前问题如何变成子问题。
  • 举个例子:

题目:写一个函数,求n的阶乘。

def f(n):
    # 递归出口
    if n <= 1:
        return 1
    ans = n * f(n - 1)
    return ans
print(f(5))

运行结果:

我来解释一下这几行代码的计算过程:

输入5后,开始调用函数;

5 > 1,则f(5)= 5 * f(4) ;

4 > 1 , 则f(4)= 4 * f(3) ;

3 > 1 , 则f(3)= 3 * f(2) ;

2 > 1 , 则f(2)= 2 * f(1) ;

1 = 1 , 则f(1)= 1 ;

最终结果为:f(5) = 5 * 4 * 3 * 2 * 1 = 120

ok,具体计算过程就是这样。

2.汉诺塔问题

我不会做动画,只能通过文字描述,我尝试过用word作图,但效果没那么好,所有就不粘贴图了

大家应该都玩过这个游戏,有n个不同大小的圆盘和三根木柱(记为a,b,c),开始时,这些圆盘由大到小依次套到木柱a上,我们要做的就是把a上的圆盘通过b全部转移到c上,而且顺序也是从小到大。

游戏规则:(1)一次只能移动一个圆盘;(2)圆盘只能在3个木柱上存放;(3)在移动过程中,不允许大盘压小盘。

当n = 1时,只有一个盘子,移动一次就可以把a木柱上是所有盘中全部移动到c木柱上;

当n = 2时,以b木柱为中间桥梁,此时a木柱上有两个木柱(记为1,2),先把圆盘1移动到b木柱上,再把圆盘2移动到木柱c上,最后,再把圆盘1移动到木柱c上就ok了。所有,需移动3次

......

具体操作步骤就是这样。

  • 我把它转化成题的形式

定义函数Move,有n个盘子 ,3个木柱(记为A,B,C),圆盘从A移动到C,中间需借助B来完成。

即Move(n, A, B, C);

考虑n个盘子的时候,将上面的(n - 1)个盘子视为一个整体:

(1)首先将(n - 1)个盘子从A移动到B,通过C,这就又变成了一个递归问题,即

Move(n - 1, A, C, B);

(2)然后将A上剩下的那个圆盘移动到C,即A --> C;

(3)最后将(n - 1)个圆盘从B移动到C,通过A,又是一个递归函数,即Move(n - 1, B , C , A);

(4)n = 0时,就是递归出口。

变成代码就是:

def  Move(n,A,B,C):
    # 递归出口
    if n == 0:
        return
    # n - 1个盘子从A移动到B,通过C
    Move(n-1,A,C,B)
    # 第n个盘子从A移动到C
    print('{} --> {}'.format(A,C))
    # n-1个盘子从B移动到C
    Move(n-1,B,A,C)

Move(3,'A','B','C')

当n = 3时,运行结果为:

这个思想就是把一个问题转化为n个子问题。 

例题: 

题目描述:

我们要求找出具有下列性质的数的个数(包括输入的自然数n) 

先输入一个自然数n(n <= 1000),然后对此自然数按照如下方法进行处理:

1.不作任何处理;

2.在它的左边加上一个自然数,但该自然数不能超过该数的一半;

3.加上自然数后,继续按此规则进行处理,直到不能再加自然数为止。

思路:

将该问题分解成若干个子问题,上述操作等价于f(n)分解成所有f(i)方案之和,i <= n//2。

参考答案:

def f(n):
    if n == 1:
        return 1
    ans = 1
    for i in range(1,n //2 + 1):
        ans += f(i)
    return ans
n = int(input())
print(f(n))

运行结果:

其中快速排序和归并排序也是递归的典型例子,可以结合着看。

若有疑问,可以提出。

OK,这篇就写到这里 ,下次继续!

       

         

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Django知识随笔

目录 1.如何再ajax中传输post数据&#xff1f; 1.如何再ajax中传输post数据&#xff1f; 在ajax传递的那个网址&#xff0c;会调用你路由的视图函数&#xff0c;在视图函数上面加一句 csrf_exempt 。写上之后会有提示让你导入类。

[嵌入式系统-4]:龙芯1B 开发学习套件-1-开发版硬件介绍

目录 前言&#xff1a; 一、龙芯 1B 开发学习套件简介 1.1 概述 二、龙芯1B 200开发板硬件组成与接口介绍 2.1 概述 2.2 核心板 2.2.1 CPU 2.2.2 什么是核心板 2.2.3 龙芯1B 200核心板 2.2.4 龙芯1B核心板的接口定义 2.3 开发板 2.3.1 龙芯1B0200开发板 2.3.2 龙芯…

微信小程序Skyline在手机端不渲染的问题之一及其解决方式

问题&#xff1a;电脑端是skyline渲染&#xff0c;手机端是webview渲染?如何解? 开发者工具 当前渲染模式&#xff1a;Skyline 当进行预览时手机端却是: 请注意看轮播图的显示情况 请注意看轮播图的显示情况 请注意看轮播图的显示情况 从轮播图上来看,手机端是webview渲染…

YOLOv8实例分割实战:TensorRT加速部署

课程链接&#xff1a;https://edu.csdn.net/course/detail/39273 PyTorch版的YOLOv8支持高性能实时实例分割方法。 TensorRT是针对英伟达GPU的加速工具。 本课程讲述如何使用TensorRT对YOLOv8实例分割进行加速和部署&#xff0c;实测推理速度提高3倍以上。  采用改进后的t…

【MCAL】TC397+EB-tresos之GPT配置实战 - 定时器

本篇文章介绍了在TC397平台使用EB-tresos对GPT驱动模块进行配置的实战过程,不仅介绍了使用GTM来实现定时器的方案&#xff0c;还介绍了基于GPT12来实现连续定时器的实例。因为GTM是德国博世公司开发的IP&#xff0c;而英飞凌的芯片集成了这个IP&#xff0c;并在这个基础上搭建了…

SpringMVC(十)拦截器

一、拦截器的配置 SpringMVC中的拦截器用于拦截控制器方法的执行 SpringMVC中的拦截器需要实现Handlerinterceptor SpringMVC中的拦截器必须在SpringMVC中的配置文件中进行配置 服务器的三大组件:servlet、filter(过滤器:在浏览器和目标资源之间进行过滤,我们从浏览器发送的…

Nodejs前端学习Day5

苦其心志&#xff0c;劳其筋骨 文章目录 前言一、处理路径问题二、path路径模块总结 前言 继续fs 一、处理路径问题 在使用fs模块操作文件时&#xff0c;如果提供的操作路径是以./或…/开头的相对路径时&#xff0c;很容易出现路径动态拼接错误的问题 原因&#xff1a;代码在…

深度强化学习(王树森)笔记07

深度强化学习&#xff08;DRL&#xff09; 本文是学习笔记&#xff0c;如有侵权&#xff0c;请联系删除。本文在ChatGPT辅助下完成。 参考链接 Deep Reinforcement Learning官方链接&#xff1a;https://github.com/wangshusen/DRL 源代码链接&#xff1a;https://github.c…

内网安全:Exchange服务

目录 Exchange服务 实验环境 域横向移动-内网服务-Exchange探针 一. 端口扫描 二. SPN扫描 三. 脚本探针(还可以探针是否有安全漏洞) 域横向移动-内网服务-Exchange爆破 一 .BurpSuite Intruder模块爆破 域横向移动-内网服务-Exchange漏洞 CVE-2020-17144 Exchange R…

嵌入式Linux系统下的智能家居能源管理系统的设计与实现

大家好&#xff0c;今天给大家介绍嵌入式Linux系统下的智能家居能源管理系统的设计与实现&#xff0c;文章末尾附有分享大家一个资料包&#xff0c;差不多150多G。里面学习内容、面经、项目都比较新也比较全&#xff01;可进群免费领取。 随着物联网技术的不断发展&#xff0c;…

19. 删除链表的倒数第 N 个结点(力扣LeetCode)

文章目录 19. 删除链表的倒数第 N 个结点题目描述将删除倒数第n个节点转化为删除第n个节点双指针 19. 删除链表的倒数第 N 个结点 题目描述 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回链表的头结点。 示例 1&#xff1a; 输入&#xff1a;hea…

(28)Linux 信号保存 信号处理 不可重入函数

首先介绍几个新的概念&#xff1a; 信号递达(Delivery)&#xff1a;实际执行信号的处理动作。信号未决(Pending)&#xff1a;信号从产生到递达之间的状态。信号阻塞(Block)&#xff1a;被阻塞的信号产生时将保持在未决状态&#xff0c;直达解除对该信号的阻塞&#xff0c;才执…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之CheckboxGroup组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之CheckboxGroup组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、CheckboxGroup组件 提供多选框组件&#xff0c;通常用于某选项的打开或关…

【Vue实用功能】Vue实现文档在线预览功能,在线预览PDF、Word等office文件

1、Office Web(微软的开发接口) 优点 没有 Office也可以直接查看Office 文件适用于移动端、PC无需下载文件就可以在浏览器中查看 <iframe src"文档地址" frameborder"0" /> const docUrl 外网可预览的地址 const url encodeURIComponent(docUrl…

python零散学习

__name__和__main__关系 python函数入口 每个模块都有一个 __name__ 属性&#xff0c;当其值是 __main__ 时&#xff0c;表明该模块自身在运行&#xff08;此时__name____main__&#xff09;&#xff0c;否则是被引入&#xff08;此时__name__自身的模块名称&#xff09;。 变…

深度强化学习(王树森)笔记06

深度强化学习&#xff08;DRL&#xff09; 本文是学习笔记&#xff0c;如有侵权&#xff0c;请联系删除。本文在ChatGPT辅助下完成。 参考链接 Deep Reinforcement Learning官方链接&#xff1a;https://github.com/wangshusen/DRL 源代码链接&#xff1a;https://github.c…

SpringBoot整合Quartz任务,java对任务创建、删除、修改、查询

SpringBoot整合Quartz定时任务 1、定时任务相关概念2、SpringBoot集成Quartz2.1、Quartz相关表2.2、pom.xml2.3、application.yml2.4、java对任务增删改查2.4.1、common相关配置类2.4.2、pojo类2.4.3、task类2.4.4、Controller类 3、一些理解3.1、Quartz的集群原理以及配置&…

Android 基础技术——Bitmap

笔者希望做一个系列&#xff0c;整理 Android 基础技术&#xff0c;本章是关于 Bitmap Bitmap 内存如何计算 占用内存 宽 * 缩放比例 * 高 * 缩放比例 * 每个像素所占字节 缩放比例 设备dpi/图片所在目录的dpi Bitmap加载优化&#xff1f;不改变图片质量的情况下怎么优化&am…

AlmaLinux上安装Docker

AlmaLinux上安装Docker 文章目录 AlmaLinux上安装Docker一、前言二、具体步骤1、Docker 下载更新系统包索引&#xff1a;添加Docker仓库&#xff1a;安装Docker引擎&#xff1a; 2、Docker服务启动启动Docker服务&#xff1a;设置Docker开机自启&#xff1a; 3、Docker 安装验证…

基于SSM的网络办公系统(有报告)。Javaee项目。ssm项目。

演示视频&#xff1a; 基于SSM的网络办公系统&#xff08;有报告&#xff09;。Javaee项目。ssm项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&#xff0c;通过Spring Spri…