贪心算法-860.柠檬水找零-力扣(LeetCode)

一、题目解析

我们需要注意我们是没有初始零钱的,所以当第一个顾客支付10或20时,无法找零此时返回false。

二、算法解析

根据贪心算法的解决方式,我们需要先把解决该问题分解为若干步。

首先对于顾客支付的钱共有三种,5,10,20,我们需要对其分别讨论。

当顾客支付5元时,我们直接收下,用于当做零钱使用。

当顾客支付10元时,我们要先判断是否有零钱补,如果没有则返回false,有则补5元。

当顾客支付20元时,我们有两种补钱方式(这里就用到了贪心),一种是10+5,另一种是5+5+5.

当20,10的时候,用了下面种补钱方式,10元就无法补钱,所以优先使用10+5的补钱方式,其次是5+5+5的补钱方式,如果两种都不满足,则返回false。

这里可以根据原理实现代码,链接:860. 柠檬水找零 - 力扣(LeetCode) 证明在结尾,如果有兴趣可以看看。

三、代码示例

cpp 复制代码
class Solution {
public:
    bool lemonadeChange(vector<int>& bills) 
    {
        int a = 0,b = 0;//a代表5元的张数,b代表10元的张数
        for(int i = 0;i<bills.size();i++)
        {
            if(bills[0] == 10 || bills[0] == 20) return false;
            if(bills[i] == 5) a++;
            if(bills[i] == 10)
            {
                if(a != 0)
                {
                    a--;
                    b++;
                }
                else return false;
            }
            if(bills[i] == 20)
            {
                if(a>=1 && b>= 1)//贪心
                {
                    a--;
                    b--;
                }
                else if(a>=3)
                {
                    a -= 3;
                }
                else return false;
            }
        }
        return true;
    }
};

四、证明

为什么贪心解就是最优解呢?这需要用数学的证明方法来证明。

看到最后,如果对您有帮助还请留下一个免费的赞和收藏,小编感激不尽,我们下期再见!

相关推荐
仟濹1 小时前
【C/C++】整数超过多少位时用「高精度」
c语言·c++·算法
DIY机器人工房4 小时前
一个可以检测本机的字节顺序,并对任意数据进行字节顺序的反转操作的代码。
嵌入式硬件·算法·嵌入式·diy机器人工房
新手小新5 小时前
C++游戏开发(2)
开发语言·前端·c++
杰克尼5 小时前
11. 盛最多水的容器
算法·leetcode·职场和发展
程序员编程指南7 小时前
Qt 嵌入式界面优化技术
c语言·开发语言·c++·qt
程序员Xu7 小时前
【OD机试题解法笔记】查找接口成功率最优时间段
笔记·算法
逝雪Yuki8 小时前
数据结构与算法——字典(前缀)树的实现
数据结构·c++·字典树·前缀树·左程云
技术思考者8 小时前
Leetcode - 反转字符串
数据结构·算法·leetcode
卷卷的小趴菜学编程8 小时前
Qt-----初识
开发语言·c++·qt·sdk·qt介绍
程序员编程指南9 小时前
Qt 开发 IDE 插件开发指南
c语言·c++·ide·qt·elasticsearch