• 蓝桥杯 2240. 买钢笔和铅笔的方案数c++解法


            最近才回学校。在家学习的计划不翼而飞。但是回到学校了,还是没有找回状态。

            现在是大三了,之前和同学聊天,说才大三无论是干什么,考研,找工作,考公,考证书 还都是来的及的。        但是心里面有点慌 还要学习的东西太多了,离找工作的标准还很远,考研的话英语又是道坎。    也许是越使人痛苦的东西自己越想去逃避。不去想,也许就不会发生了。这种行为使我感到很大的罪恶感,通过去玩游戏,发呆,看小说,听音乐去逃避现实。麻木自己的内心感到的充足,逃避现实。

            所以要改变 那就现在。

    题目

    给你一个整数 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 <= 10

     思路 

    很简单的一道题

    先比较两个商品的价格,先买0个const1 在用剩下的钱看可以买几个const2  将(total-num*cost1)/cost2+1;结果进行累加 ,在买1个const1..... 直到剩下的钱不能买num个const1为止。

    循环计算的方法来解决买钢笔和铅笔的方案数问题。具体解释如下:

    1. 首先检查cost1和cost2的大小关系如果cost1大于cost2,则交换它们的值,以确保cost1表示价格较低的钢笔。

    2. 初始化变量num和sum,分别用于迭代计数和累计方案数。

    3. 使用一个while循环,当num乘以cost1小于等于total时进行迭代。

    4. 在循环体内,计算剩余钱数(total-num*cost1)除以cost2,并加1,表示可以购买的铅笔的数量。将该数量累加到sum中。

    5. 将num增加1,继续下一轮循环。

    6. 当循环结束后,返回sum,即为购买钢笔和铅笔的不同方案数。

    该方法的思路是遍历钢笔数量num,计算每个num对应的铅笔数量,然后累加到总方案数sum中。时间复杂度为O(total/cost1)。

    1. class Solution {
    2. public:
    3. long long waysToBuyPensPencils(int total, int cost1, int cost2) {
    4. if(cost1
    5. return waysToBuyPensPencils(total,cost2,cost1);
    6. long num=0,sum=0; //注意num的范围用long进行定义防止溢出
    7. while(num*cost1<=total)
    8. {
    9. sum+=(total-num*cost1)/cost2+1;
    10. num++;
    11. }
    12. return sum;
    13. }
    14. };

     

  • 相关阅读:
    戏说领域驱动设计(十八)——内验
    PE文件之导入表
    目标检测——食品饮料数据集
    简单易懂的 全景图高清下载方法以及原理简要解析(支持下载建E、720yun、酷雷曼、景站、酷家乐、百度街景原图)
    机器学习简述
    python 如何根据索引快速删除列表中的多个元素
    【Linux-常用命令-基础命令-删除文件夹以及内容-rm--r-命令-笔记】
    current file is not included in a workspace moduleg 存在多个 main函数的 Go项目 无法成功导包
    map方法的使用:将原数组的每一项的属性值放大三倍?
    如何理解“构造函数是类公共标识,但原型是唯一的标识“
  • 原文地址:https://blog.csdn.net/qq_64200765/article/details/132626146