力扣LeetCode刷题心得之Python 买钢笔和铅笔的方案数

6061. 买钢笔和铅笔的方案数

给你一个整数 total ,表示你拥有的总钱数。同时给你两个整数 cost1 和 cost2 ,分别表示一支钢笔和一支铅笔的价格。你可以花费你部分或者全部的钱,去买任意数目的两种笔。

请你返回购买钢笔和铅笔的 不同方案数目 。

示例 1:

输入:total = 20, cost1 = 10, cost2 = 5
输出:9
解释:一支钢笔的价格为 10 ,一支铅笔的价格为 5 。

  • 如果你买 0 支钢笔,那么你可以买 0 ,1 ,2 ,3 或者 4 支铅笔。
  • 如果你买 1 支钢笔,那么你可以买 0 ,1 或者 2 支铅笔。
  • 如果你买 2 支钢笔,那么你没法买任何铅笔。 所以买钢笔和铅笔的总方案数为 5 + 3 + 1 = 9 种。

示例 2:

输入:total = 5, cost1 = 10, cost2 = 10
输出:1
解释:钢笔和铅笔的价格都为 10,都比拥有的钱数多,所以你没法购买任何文具。所以只有 1 种方案:买 0 支钢笔和 0 支铅笔。

提示:

1 <= total, cost1, cost2 <= 106

来源:力扣

解题思路:

第一步,光买钢笔有几种方案

 a = int(total/cost1)+1

因为0只钢笔也算一种方案,所以加一

第二步,买钢笔后,剩下的钱能购买多少铅笔

int((total-cost1*n)/cost2)

第三步,在买钢笔的几种方案下,剩下的钱购买铅笔有几种方案

for n in range(a):
    int((total-cost1*n)/cost2)+1

第四步,将所有方案相加

b = 0
for n in range(a):
    b += int((total-cost1*n)/cost2)+1

代码整合:

class Solution(object):
    def waysToBuyPensPencils(self, total, cost1, cost2):
        """
        :type total: int
        :type cost1: int
        :type cost2: int
        :rtype: int
        """
        a = int(total/cost1)+1
        b = 0
        for n in range(a):
            b += int((total-cost1*n)/cost2)+1
        return b
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南蓬幽

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值