Python算法100例-1.4 百钱百鸡

  • 1.问题描述
  • 2.问题分析
  • 3.算法设计
  • 4.知识点补充
  • 5.确定程序框架
  • 6.确定公鸡、母鸡和小鸡数量
  • 7.完整的程序
  • 8.问题拓展

完整源代码项目地址,关注博主私信’源代码’后可获取

1.问题描述

中国古代数学家张丘建在他的《算经》中提出了一个著名的“百钱百鸡问题”:一只公鸡值五钱,一只母鸡值三钱,三只小鸡值一钱,现在要用百钱买百鸡,请问公鸡、母鸡、小鸡各多少只?

2.问题分析

用百钱如果只买公鸡,最多可以买20只,但题目要求买100只,由此可知,所买公鸡的数量肯定在0~20之间。同理,母鸡的数量在0~33之间。在此不妨把公鸡、母鸡和小鸡的数量分别设为cock、hen、chicken,则cock+hen+chicken=100,因此百钱买百鸡问题就转化成解不定方程组的问题。

在这里插入图片描述

3.算法设计

对于不定方程组,我们可以利用穷举循环的方法来解决,也就是通过对未知数可变范围的穷举,验证方程在什么情况下成立,从而得到相应的解。因公鸡的取值范围是0~20,可用循环语句“for cock in range(0,21);”实现。钱的数量是固定的,要买的鸡的数量也是固定的,所以母鸡数量是受到公鸡数量限制的。同理,小鸡数量受到公鸡和母鸡数量的限制,因此我们可以利用三层循环的嵌套来解决,第一层循环控制公鸡的数量,第二层控制母鸡的数量,最内层控制小鸡的数量。

4.知识点补充

结构化程序设计包括三种基本结构:顺序结构、选择结构(分支结构)和循环结构(重复结构),利用这三种基本结构可以解决很多复杂问题。

·顺序结构:一种简单的程序设计,按照程序中语句的顺序依次执行,每条语句都能被执行且只执行一次。

·选择结构:包括简单选择和多分支选择结构,可根据条件,判断应该选择哪一条分支来执行相应的语句序列。简单选择结构采用简单或一般的if语句即可解决,对于复杂的选择结构可以使用嵌套的if…elif…else语句实现。

·循环结构:可根据给定条件,判断是否需要重复执行某一相同程序段。

下面介绍Python语言的循环结构。

(1)while循环

while循环语法格式如下:

while 判断条件:

  执行语句

其中,判断条件可以是任何表达式,所有非空、非零的值都为True,当判断条件为False时,循环结束;执行语句可以是单条语句,也可以是一个语句块。

(2)for循环

for循环语法格式如下:

for iterating_var in sequence:

  statements(s),

其中,sequence是任意序列,如列表(数组)、字典或元组等,也可以通过range()函数产生一个整数列表,以完成计数循环;iterating_var是序列中需要遍历的元素;statements是待执行的语句块。

range()函数使用格式如下:

range([start , ] stop[ , step])

其中,start为可选参数,表示起始数;stop为终止数,如果range()函数只有一个参数n,则将产生一个0~(n-1)的整数列表,也就是循环n-1次;step为可选参数,表示循环步长,不写时,默认步长为1。

需要注意的是,while循环结构首先对while条件进行判断,当条件为True时,执行条件语句块;当执行完语句块时,再次判断while条件是否为True,若仍然为True,则继续执行语句块,直到条件为False时结束循环。

while循环结构的流程图如图所示。

在这里插入图片描述

(3)for循环结构

for循环结构首先对for语句的条件判断,游标(序列都会有一个游标,游标一般从第0个位置开始)指向序列的第0个位置,也就是序列的第一个元素,判断序列sequence中是否有元素。如果有,就将这个元素赋值给iterating_var,然后执行循环体语句块,执行完成后,游标下移一位,再次判断该位置是否有元素;如果有,继续将该元素赋值给iterating_var,继续执行循环语句块;游标再往下移一位,一直循环下去,直到下一个位置没有元素时结束循环。

for循环结构的流程图如图所示。

在这里插入图片描述

在循环语句中,循环体可以是由一个或多个语句构成的,当其中某个语句是循环语句时,即一个循环体中完整地包含了另外一个循环,就形成了循环嵌套结构,我们称之为多重循环,并且把这个循环语句称为外层循环语句,而把循环体中的循环语句称为内层循环语句。在理解多重循环语句时,只要把内层循环语句看作是外层循环语句的循环体的一部分就可以了。在程序执行时,外层循环语句与内层循环语句的关系,有点像钟表的时针与分针的关系,分针走了60格,时针才走1格。对于多重循环来说,只有内层循环语句执行到判断条件为假时,才返回到其上层循环语句继续执行。

5.确定程序框架

在设计循环时首先要考虑循环的三要素,即循环变量的初值、循环的控制条件和使循环趋于结束的循环变量值的改变。

针对本题来说,每层循环的初值是0(即买的100只鸡中,可能没有公鸡,也可能没有母鸡或小鸡);循环的控制条件是公鸡、母鸡和小鸡用百钱最多能够买到的数量[根据上面分析可知:公鸡最多20只,母鸡最多33只,小鸡最多100只(虽然百钱最多可以买到300只小鸡,但题目要求只买100只)];穷举循环的特点就是把所有情况都考虑到,因此每层循环执行一次,对应循环变量的值就要加1。

程序流程图如图所示。

在这里插入图片描述

# 根据流程图,构建程序框架如下:
cock = 0
while cock <= 20:# 内层循环控制母鸡数量取值范围为0~33hen = 0while hen <= 33:#内层循环控制小鸡数量取值范围为0~100chicken = 0while chicken <= 100:#条件控制print("cock=%2d,hen=%2d,chicken=%2d\n" %(cock,hen,chicken))chicken += 1hen += 1cock += 1

6.确定公鸡、母鸡和小鸡数量

根据这三层循环我们可以得到很多种方案,在这些方案中有些是不符合cock+hen+chicken=100并且5×cock+3×hen+chicken/3=100这两个条件的。因此结果输出之前我们要把合理的方案筛选出来,即如果结果满足cock+hen+chicken=100和5×cock+3×hen+chicken/3=100,则输出。很明显,控制条件即为语句if(5×cock+3×hen+chicken/3.0100)and(cock+hen+chicken100)。

注意:在Python语言中,使用and关键字表示“逻辑与”;使用or关键字表示“逻辑或”;使用not关键字表示“逻辑非”。另外,运算符“/”表示除,x除以y,结果为带小数点的浮点数;而运算符“//”表示取整除,返回商的整数部分。

7.完整的程序

根据上面的分析,编写程序如下:

%%time
# 百钱百鸡问题
if __name__=="__main__":# cock表示公鸡数量,hen表示母鸡数量,chicken表示小鸡数量,总共100只# 外层循环控制公鸡数量取值范围为0~20cock = 0while cock <= 20:# 内层循环控制母鸡数量取值范围为0~33hen = 0while hen <= 33:#内层循环控制小鸡数量取值范围为0~100chicken = 0while chicken <= 100:# 条件控制if (5 * cock + 3 * hen + chicken / 3.0 ==100) and (cock + hen
+ chicken ==100):print("cock=%2d,hen=%2d,chicken=%2d\n" %(cock,hen,chicken))chicken += 1hen += 1cock += 1
cock= 0,hen=25,chicken=75cock= 4,hen=18,chicken=78cock= 8,hen=11,chicken=81cock=12,hen= 4,chicken=84CPU times: user 56.9 ms, sys: 2.29 ms, total: 59.2 ms
Wall time: 56.1 ms

8.问题拓展

以上算法需要穷举尝试21×34×101=72 114次,算法的效率显然太低了。对于这类求解不定方程的问题,各层循环的控制变量直接与方程的未知数相关,并且采用对未知数的取值范围穷举和组合的方法得到全部的解。对于本题来说,公鸡的数量确定后,小鸡的数量就固定为100-cock-hen,无须再进行穷举了,此时约束条件只有一个,即5×cock+3×hen+chicken/3=100,这样我们利用两重循环即可求解本题,代码如下:

%%time
# 百钱百鸡问题if __name__=="__main__":# 外层循环控制公鸡数量取整范围为0~20cock = 0while cock <= 20:# 内层循环控制母鸡数量取值范围为0~30hen = 0while hen <= 33:# 小鸡的数量chicken = 100 - cock - henif 5 * cock + 3 * hen + chicken / 3.0 == 100:print("cock=%2d,hen=%2d,chicken=%2d\n" %(cock, hen, chicken))hen+=1cock+=1
cock= 0,hen=25,chicken=75cock= 4,hen=18,chicken=78cock= 8,hen=11,chicken=81cock=12,hen= 4,chicken=84CPU times: user 585 µs, sys: 0 ns, total: 585 µs
Wall time: 590 µs

此算法只需穷举21×34=714次,实现时约束条件又限定chicken能被3整除时才会判断“5×cock+3×hen+chicken/3.0=100”,这样便省去了chicken不能整除3时的算术计算和条件判断,进一步提高了算法的效率。算法运行时间大幅缩短

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

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

相关文章

动态规划的一个初步学习

啥叫动态规划 在我们写很多的题目时&#xff0c;常常可以用暴力枚举来写&#xff0c;缺点就是速度太慢了。如果我们用一个数组或者哈希表&#xff08;虽然我还没学过哈希表&#xff09;将之前暴力枚举的数据储存起来&#xff0c;当再一次枚举到这个数字的时候就直接调用数组或…

Android---Jetpack Compose学习002

Compose 布局。Compose 布局的目标&#xff1a;1&#xff09;实现高性能&#xff1b;2&#xff09;让开发者能够轻松编写自定义布局&#xff1b;3&#xff09;在 Compose 中&#xff0c;通过避免多次测量布局子级可实现高性能。如果需要进行多次测量&#xff0c;Compose 具有一…

分享86个表单按钮JS特效,总有一款适合您

分享86个表单按钮JS特效&#xff0c;总有一款适合您 86个表单按钮JS特效下载链接&#xff1a;https://pan.baidu.com/s/1WwQGFPWv8464JBcuEMJZ_Q?pwd8888 提取码&#xff1a;8888 Python采集代码下载链接&#xff1a;采集代码.zip - 蓝奏云 学习知识费力气&#xff0c;…

spring boot学习第十二篇:mybatis框架中调用存储过程控制事务性

1、MySQL方面&#xff0c;已经准备好了存储过程&#xff0c;参考&#xff1a;MYSQL存储过程&#xff08;含入参、出参&#xff09;-CSDN博客 2、pom.xml文件内容如下&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"…

SpringCloud--Eureka注册中心服务搭建注册以及服务发现

注意springboot以及springcloud版本&#xff0c;可能有莫名其妙的错误&#xff0c;这里使用的是springboot-2.6.13&#xff0c;springcloud-2021.0.5 一&#xff0c;Eureka-Server搭建&#xff1a; 1.创建项目&#xff1a;引入依赖 <dependency><groupId>org.sp…

[C/C++] -- Boost库、Muduo库编译安装使用

1.Muduo库 Muduo 是一个基于 C11 的高性能网络库&#xff0c;其核心是事件驱动、非阻塞 I/O、线程池等技术&#xff0c;以实现高并发、高性能的网络通信。Muduo 库主要由陈硕先生开发维护&#xff0c;已经成为 C 服务器程序员的常用工具之一。 Muduo 库的主要特点&#xff1a…

Javaweb之SpringBootWeb案例之事务管理的详细解析

1. 事务管理 1.1 事务回顾 在数据库阶段我们已学习过事务了&#xff0c;我们讲到&#xff1a; 事务是一组操作的集合&#xff0c;它是一个不可分割的工作单位。事务会把所有的操作作为一个整体&#xff0c;一起向数据库提交或者是撤销操作请求。所以这组操作要么同时成功&am…

MySQL数据库⑥_内置函数(日期函数+字符串函数+数学函数等)

目录 1. 日期函数 2. 字符串函数 3. 数学函数 4. 其它函数 本篇完。 1. 日期函数 MySQL常用的日期函数如下&#xff1a; 函数名称描述current_date()获取当前日期current_time()获取当前时间current_timestamp()获取当前时间戳now()获取当前日期时间date(datetime)获取d…

深度学习的进展及其在各领域的应用

深度学习&#xff0c;作为人工智能的核心分支&#xff0c;近年来在全球范围内引起了广泛的关注和研究。它通过模拟人脑的学习机制&#xff0c;构建复杂的神经网络结构&#xff0c;从大量数据中学习并提取有用的特征表示&#xff0c;进而解决各种复杂的模式识别问题。 一、深度…

百面嵌入式专栏(面试题)驱动开发面试题汇总1.0

沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本篇我们将介绍驱动开发面试题 。 1、Linux驱动程序的功能是什么? 对设备初始化和释放。进行内核与硬件的数据交互。检测和处理设备出现的错误。2、内核程序中申请内存使用什么函数? 答案:kmalloc()、kzalloc()、vm…

C++Linux网络编程day02:select模型

本文是我的学习笔记&#xff0c;学习路线跟随Github开源项目&#xff0c;链接地址&#xff1a;30dayMakeCppServer 文章目录 select模型fd_set结构体 timeval结构体文件描述符的就绪条件带外数据与普通数据socket的状态 select模型 select是Linux下的一个IO复用模型&#xff…

Flink基础篇|002_Flink前世今生

&#x1f4eb; 作者简介&#xff1a;「六月暴雪飞梨花」&#xff0c;专注于研究Java&#xff0c;就职于科技型公司后端工程师 &#x1f3c6; 近期荣誉&#xff1a;华为云云享专家、阿里云专家博主、腾讯云优秀创作者 &#x1f525; 三连支持&#xff1a;欢迎 ❤️关注、&#x…

latex双列排版下,插入表格但在单独一页出现,换页出现

问题描述&#xff1a; 在双列排版中&#xff0c;由于需要插入单列的整块表格&#xff0c;但表格出现在新的一页&#xff0c;如图&#xff1a; 解决&#xff1a; 注意是hb&#xff0c;不是htbp \begin{figure*}[hb] \centering \includegraphics[scale0.4]{img1.jpg} \caption…

2-2 动手学深度学习v2-损失函数-笔记

损失函数&#xff0c;用来衡量预测值和真实值之间的区别。是机器学习里面一个非常重要的概念。 三个常用的损失函数 L2 loss、L1 loss、Huber’s Robust loss 均方损失 L2 Loss l ( y , y ′ ) 1 2 ( y − y ′ ) 2 l(y,y^{\prime})\frac{1}{2}(y-y^{\prime})^{2} l(y,y′)21…

飞天使-k8s知识点14-kubernetes散装知识点3-Service与Ingress服务发现控制器

文章目录 Service与Ingress服务发现控制器存储、配置与角色 Service与Ingress服务发现控制器 在 Kubernetes 中&#xff0c;Service 和 Ingress 是两种不同的资源类型&#xff0c;它们都用于处理网络流量&#xff0c;但用途和工作方式有所不同。Service 是 Kubernetes 中的一个…

【Flink入门修炼】1-2 Mac 搭建 Flink 源码阅读环境

在后面学习 Flink 相关知识时&#xff0c;会深入源码探究其实现机制。因此&#xff0c;需要现在本地配置好源码阅读环境。 本文搭建环境&#xff1a; Mac M1&#xff08;Apple Silicon&#xff09;Java 8IDEAFlink 官方源码 一、 下载 Flink 源码 github 地址&#xff1a;h…

【设计模式】23中设计模式笔记

设计模式分类 模板方法模式 核心就是设计一个部分抽象类。 这个类具有少量具体的方法&#xff0c;和大量抽象的方法&#xff0c;具体的方法是为外界提供服务的点&#xff0c;具体方法中定义了抽象方法的执行序列 装饰器模式 现在有一个对象A&#xff0c;希望A的a方法被修饰 …

一、基础算法之排序、二分、高精度、前缀和与差分、双指针算法、位运算、离散化、区间合并内容。

1.快速排序 算法思想&#xff1a;选择基准元素&#xff0c;比基准元素小的放左边&#xff0c;比基准元素大的放右边。每趟至少一个元素排好。 每一趟实现步骤&#xff1a; low>high&#xff0c;返回&#xff0c;排序完成选取基准元素xa[low],ilow,jhigh当i<j时&#x…

ZOJ 3537 Cake 【区间DP + 凸多边形三角剖分】

Cake 题意 给定平面坐标上的 n n n 个点&#xff0c;如果是凸多边形的话&#xff0c;就用最少的花费把这个多边形剖分成若干个三角形&#xff0c;剖分的线段端点只能是原多边形的顶点&#xff0c;一条线段的花费为&#xff1a; ∣ x i x j ∣ ∣ y i y j ∣ m o d p |x_i…

部署一个在线OCR工具

效果 安装 1.拉取镜像 # 从 dockerhub pull docker pull mmmz/trwebocr:latest 2.运行容器 # 运行镜像 docker run -itd --rm -p 10058:8089 --name trwebocr mmmz/trwebocr:latest 使用 打开浏览器输入 http://192.168.168.110:10058/ 愉快滴使用吧