贪心算法-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++·算法
j_xxx404_1 小时前
C++ STL:阅读list源码|list类模拟|优化构造|优化const迭代器|优化迭代器模板|附源码
开发语言·c++
散峰而望1 小时前
C/C++输入输出初级(一) (算法竞赛)
c语言·开发语言·c++·算法·github
Kuo-Teng1 小时前
LeetCode 160: Intersection of Two Linked Lists
java·算法·leetcode·职场和发展
fie88892 小时前
基于MATLAB的狼群算法实现
开发语言·算法·matlab
曾几何时`2 小时前
C++——this指针
开发语言·c++
偷偷的卷2 小时前
【算法笔记 11】贪心策略六
笔记·算法
小冯的编程学习之路2 小时前
【C++】: C++基于微服务的即时通讯系统(1)
开发语言·c++·微服务
ZPC82103 小时前
FPGA 部署ONNX
人工智能·python·算法·机器人
_w_z_j_3 小时前
爱丽丝的人偶
算法