python算法:百钱买百鸡

一,for循环:

1,功能:重复执行同一段代码
语法:

for index in range(n): 
    # 循环体代码

index : 用来依次接收可迭代对象中的元素的变量名
range()函数:负责返回整数序列

流程图:

2,应用

range可以同时指定start 和stop,用for遍历并打印

1
2
3
4
# 指定 start和stop
# print的参数 end=" " 用来使打印不换行
for num in range(3,9):
    print(num, end=" ")

运行结果:

3 4 5 6 7 8 

说明:刘宏缔的架构森林—专注it技术的博客,
网址:https://imgtouch.com
本文: https://blog.imgtouch.com/index.php/2024/03/13/python-suan-fa-bai-qian-mai-bai-ji/
代码: https://github.com/liuhongdi/ 或 https://gitee.com/liuhongdi
说明:作者:刘宏缔 邮箱: 371125307@qq.com

二,百钱买百鸡题目与分析

1,题目:

用一百块钱去买一百只鸡,
公鸡5块钱1只,
母鸡3块钱1只,
小 鸡1块钱3只。
请问一百块能买到公鸡,母鸡,小鸡各多少只?

2,分析:

思路:
100块钱买一种鸡最多能买多 少只?
买公鸡最多只能买20只,
母鸡能买33只,
小鸡能买300只,但鸡的数量限定在100只
公鸡数量+母鸡数量+小鸡数量 =100只。
在确定一种鸡的数量下去求另外两种鸡的数量组合。
这种穷举方式非常适合用循环 来解决

三,代码实现:

1,两层循环:

1
2
3
4
5
6
# 百钱买百鸡问题
for x in range(21):                      # 公鸡最多可以买20只
    for y in range(34):                  # 母鸡最多可以买33只
        z = 100 - x - y                  # 小鸡的数量等于100-x-y
        if z % 3 == 0 and (5 * x + 3 * y + z // 3 == 100):
            print(f'公:{x},母:{y},小:{z}')

运行结果:

公:0,母:25,小:75
公:4,母:18,小:78
公:8,母:11,小:81
公:12,母:4,小:84

2,一层循环

两次循环的性能仍然可以优化,因为有这个方程存在:

x+y+z = 100
5*x+3*y+z/3 = 100

所以我们可以通过解方程得到y与x之间的关系,
这样就可以减少一层循环

1
2
3
4
5
6
for x in range(0, 21):
    y = (200 - 14 * x) / 8    # 根据解方程得到y值
    if y > 0 and y == int(y):   # 如果y为正数且为整数
        z = 100 - x - y     # 得到小鸡数量
        if z > 0:
            print(f'公:{x},母:{int(y)},小:{int(z)}')

运行结果:

公:0,母:25,小:75
公:4,母:18,小:78
公:8,母:11,小:81
公:12,母:4,小:84
posted @ 2024-05-15 10:21  刘宏缔的架构森林  阅读(1521)  评论(0编辑  收藏  举报