Python算法100例-1.4 百钱百鸡

2024-02-07 11:04
文章标签 python 算法 1.4 100 百钱 百鸡

本文主要是介绍Python算法100例-1.4 百钱百鸡,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

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时的算术计算和条件判断,进一步提高了算法的效率。算法运行时间大幅缩短

这篇关于Python算法100例-1.4 百钱百鸡的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/687500

相关文章

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核