iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python递归实现猴子吃桃问题及解析
  • 594
分享到

Python递归实现猴子吃桃问题及解析

2024-04-02 19:04:59 594人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录python递归实现猴子吃桃Python函数(闰年&猴子偷桃)问题函数作业Python递归实现猴子吃桃 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多

Python递归实现猴子吃桃

猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了,求第一天共摘了多少桃子?

对于此性质的问题适合用递归的思想去解决,即当前问题可以转化为性质相同的子问题去解决:

要想知道第一天的桃子数量,需要知道第二天的桃子数量,然后将第二天的桃子数量加1乘以2就可以得到第一天的桃子数量。按照此法进行倒推,我已知道第十天的桃子数量为1个,则第九天的桃子数量为第10天的桃子数量加1乘以2,第八天的桃子数量等于第九天的数量加1再乘以2,...

则可以定义函数去实现:n代表天数,如果输入的n不合理,则直接退出函数,如果n等于10,则返回1,否则返回其后面天数桃子数量加1再乘以2

代码如下:

def monkey_tao(n):
    if n>10 or n<1:
        return
    elif n==10:
        return 1
    else:
        return (monkey_tao(n+1)+1)*2
print (monkey_tao(1))

Python函数(闰年&猴子偷桃)问题

函数

1. 函数简介

  • 函数也是一个对象
  • 函数用来保存一些可执行的代码,并且可以在需要时,对这些语句进行多次调用
  • 语法:
def 函数名([形参1,形参2,形参3....]):
    代码块

注意:

  • 函数名必须符合标识符的规范(可以包含字母、数字、下划线但是不能以数字开头)

print是函数对象 print()是调用函数

函数的参数

形参和实参

  • 形参(形式参数) 定义形参就相当于在函数内部声明了变量,但是并不是赋值
  • 实参(实际参数)指定了形参,那么在调用函数时必须传递实参,实参将会赋值给对应的形参,简单来说有几个形参就要有几个实参

函数的传递方式

  • 定义形参时,可以为形参指定默认值。指定了默认值以后,如果用户传递了参数则默认值不会生效。如果用户没有传递,则默认值就会生效
  • 位置参数:位置参数就是将对应位置的实参赋值给对应位置的形参
  • 关键字参数 : 关键字参数可以不按照形参定义的顺序去传递,而根据参数名进行传递
  • 混合使用位置参数和关键字参数的时候必须将位置参数写到关键字参数前面去

不定长参数

  • 定义函数时,可以在形参前面加一个*,这样这个形参可以获取到所有的实参,它会将所有的实参保存到一个元组中
  • 带*号的形参只能有一个,可以和其他参数配合使用
  • *形参只能接受位置参数,不能接受关键字参数
  • **形参可以接收其他的关键字参数,它会将这些参数统一保存到字典当中。字典的key就是参数的名字,字典的value就是参数的值
  • **形参只有一个,并且必须写在所有参数的后面

参数的解包

  • 传递实参时,也可以在序列类型的参数前添加星号,这样它会自动的将序列中元素依次作为参数传递
  • 要求序列中的元素的个数必须和形参的个数一致 函数中

1.函数的返回值

  • 返回值就是函数执行以后返回的结果
  • 通过return来指定函数的返回值
  • return后面可以跟任意对象,返回值甚至可以是一个函数

2.文档字符串

  • help()是Python中内置函数,通过help()函数可以查询Python中函数的用法
  • 在定义函数时,可以在函数内部编写文档字符串,文档字符串就是对函数的说明

函数的作用域

  • 作用域(scope)
  • 作用域指的是变量生效的区域
  • 在Python中一共有两种作用域
  • 全局作用域

全局作用域在程序执行时创建,在程序执行结束时销毁

所有函数以外的区域都是全局作用域

在全局作用域中定义的变量,都是全局变量,全局变量可以在程序的任意位置进行访问

函数作用域

  • 函数作用域在函数调用时创建,在调用结束时销毁
  • 函数每调用一次就会产生一个新的函数作用域
  • 在函数作用域中定义的变量,都是局部变量,它只能在函数内部被访问

命名空间

  • 命名空间实际上就是一个字典,是一个专门用来存储变量的字典
  • locals()用来获取当前作用域的命名空间
  • 如果在全局作用域中调用locals()则获取全局命名空间,如果在函数作用域中调用locals()则获取函数命名空间
  • 返回值是一个字典

递归函数

  • 递归是解决问题的一种方式,它的整体思想,是将一个大问题分解为一个个的小问题,直到问题无法分解时,在去解决问题
  • 递归式函数有2个条件

基线条件 问题可以被分解为最小问题,当满足基线条件时,递归就不执行了

递归条件 可以将问题继续分解的条件

作业

闰年

用函数实现一个判断用户输入的年份是否是闰年的程序

  • 能被400整除的年份
  • 能被4整除,但是不能被100整除的年份

以上2种方法满足一种即为闰年

def leap_year():
    i = int(input('请输入一个年份:'))
    if i%400 == 0 or (i%4 == 0 and i%100 != 0):
        print('此年分是闰年')
    else:
        print('次年分不是闰年')
leap_year()

运行结果:

猴子吃桃问题(递归)

猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了,求第一天共摘了多少桃子?

def hou_tao(i, x):       # i为天数  x为剩余桃子数
    if i == 1:
        return x
    else:
        return (hou_tao(i-1, x) + 1)*2
print(f'第一天共摘{hou_tao(10, 1)}个桃子')

运行结果:

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: Python递归实现猴子吃桃问题及解析

本文链接: https://www.lsjlt.com/news/119443.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python递归实现猴子吃桃问题及解析
    目录Python递归实现猴子吃桃Python函数(闰年&猴子偷桃)问题函数作业Python递归实现猴子吃桃 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多...
    99+
    2024-04-02
  • PHP用递归法求猴子吃桃问题
    题目为:一个猴子守着一堆桃子,第一天吃了一半又多吃了一个,第二天一样,到第十天就剩下一个桃子,请问原来有几个桃子? 202003090206罗的解题思路是这样的: 运行结果如图所示:  -202003090206罗来源地址:https:...
    99+
    2023-10-12
    php
  • java怎么解决猴子吃桃问题
    这篇文章主要介绍“java怎么解决猴子吃桃问题”,在日常操作中,相信很多人在java怎么解决猴子吃桃问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java怎么解决猴子吃桃...
    99+
    2024-04-02
  • 使用Java怎么实现一个猴子吃桃问题算法
    使用Java怎么实现一个猴子吃桃问题算法?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。猴子吃桃问题概述:猴子第一天摘下N个桃子,当时就吃了一半,还不过瘾,就又吃了一个;第二天又...
    99+
    2023-05-31
    java
  • 递归——汉诺塔问题(python实现)
    规则 每次移动一个盘子 任何时候大盘子在下面,小盘子在上面 方法 假设共n个盘子 当n=1时: 直接把A上的一个盘子移动到C上(A->C) 当n=2时: 把小盘子从A放到B上(A->B)这里开始采用参数,rsc源...
    99+
    2023-01-30
    递归 汉诺 python
  • 解决python递归函数及递归次数受到限制的问题
    目录递归函数及递归次数受到限制求和:sum=n+n(n-1)+…+1求阶乘:n!=1x2x3…xn解决问题的办法是修改可递归的次数如何控制递归的次数第一种...
    99+
    2024-04-02
  • 递归出现栈溢出stackoverflow的问题及解决
    目录递归出现栈溢出stackoverflow递归调用中栈溢出原因递归出现栈溢出stackoverflow 递归是个不断回调方法的过程,使方法一遍遍的压入栈中,递归次数多了,栈满了也就...
    99+
    2024-04-02
  • python小球落地问题及解决(递归函数)
    目录问题什么是递归函数例子小球落地解题思路python递归函数介绍问题 一个球从 100 米高的自由落下,每次落地后反跳回原高度的一半。求第10次弹起的高度与途径的总路程 什么是递归...
    99+
    2024-04-02
  • C++ 函数的递归实现:如何使用递归来解决数学问题?
    递归是一种函数调用自身的编程技巧,用于解决复杂问题。在数学问题中,递归应用广泛,例如:计算阶乘:fac++torial(n) = n * factorial(n-1) if n >...
    99+
    2024-04-22
    c++ 递归 堆栈溢出
  • python 用递归实现通用爬虫解析器
    目录需求分析进一步分析再进一步分析代码实现我们在写爬虫的过程中,除了研究反爬之外,几乎全部的时间都在写解析逻辑。那么,生命苦短,为什么我们不写一个通用解析器呢?对啊!为什么不呢?开整...
    99+
    2024-04-02
  • 怎么在python中利用递归实现一个爬虫解析器
    怎么在python中利用递归实现一个爬虫解析器?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。另外一种是配置文件预先告知的方式,你配置成什么类型,解析器就通过对应的解析规则去解析...
    99+
    2023-06-14
  • C++std::initializer_list实现原理解析及遇到问题
     一般而言,对变量或对象使用括号初始化的方式被称为直接初始化,其本质是调用了相应的构造函数;而使用等号初始化的方式则被称为拷贝初始化,说到拷贝大家可能马上就会想到拷贝构造函...
    99+
    2024-04-02
  • Python opencv缺陷检测的实现及问题解决
    题目描述 利用opencv或其他工具编写程序实现缺陷检测。 实现过程 # -*- coding: utf-8 -*- ''' 作者 : 丁毅 开发时间 : 2021/4/21 ...
    99+
    2024-04-02
  • matlab遗传算法求解车间调度问题分析及实现源码
    目录一、车间调度简介1 车间调度定义2 传统作业车间调度二、遗传算法简介1 遗传算法概述2 遗传算法的特点和应用3 遗传算法的基本流程及实现技术3.1 遗传算法的基本流程3.2 遗传...
    99+
    2024-04-02
  • SVM算法的理解及其Python实现多分类和二分类问题
    目录原理分类理论确定最大间距SVM多分类Python实现多分类二分类总结原理 SVM被提出于1964年,在二十世纪90年代后得到快速发展并衍生出一系列改进和扩展算法,在人像识别、文本...
    99+
    2023-02-01
    SVM算法理解 Python实现多分类 Python实现二分类
  • 评价模型(一) 层次分析法(AHP),熵权法,TOPSIS分析 及其对应 PYTHON 实现代码和例题解释
    数学建模系列文章: 以下是个人在准备数模国赛时候的一些模型算法和代码整理,有空会不断更新内容: 评价模型(一)层次分析法(AHP),熵权法,TOPSIS分析 及其对应 PYTHON 实现代码和例题解释...
    99+
    2023-10-25
    数学建模
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作