贪心算法-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;
    }
};

四、证明

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

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

相关推荐
十五年专注C++开发41 分钟前
CMake基础:条件判断详解
c++·跨平台·cmake·自动化编译
森焱森1 小时前
水下航行器外形分类详解
c语言·单片机·算法·架构·无人机
QuantumStack3 小时前
【C++ 真题】P1104 生日
开发语言·c++·算法
天若有情6733 小时前
01_软件卓越之道:功能性与需求满足
c++·软件工程·软件
whoarethenext3 小时前
使用 C++/OpenCV 和 MFCC 构建双重认证智能门禁系统
开发语言·c++·opencv·mfcc
写个博客4 小时前
暑假算法日记第一天
算法
绿皮的猪猪侠4 小时前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988944 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
Jay_5155 小时前
C++多态与虚函数详解:从入门到精通
开发语言·c++
杰克尼5 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表