【代码随想录day 29】 力扣 860.柠檬水找零

视频讲解:https://www.bilibili.com/video/BV12x4y1j7DD/?vd_source=a935eaede74a204ec74fd041b917810c

文档讲解:https://programmercarl.com/0860.柠檬水找零.html#思路

力扣题目:https://leetcode.cn/problems/lemonade-change/

这道题乍一看很难,但其实没有几个判断情况

  1. 如果第一个上来就不能找零,直接false
  2. 收到5元,不用找零,收到10元,找5元
  3. 收到20就需要找一个5一个10或者三个5
  4. 一旦出现小于0的情况下,直接false,否则则为true
cpp 复制代码
class Solution {
public:
    bool lemonadeChange(vector<int>& bills) {
        int cash_5 = 0;
        int cash_10 = 0;
        int cash_20 = 0;
        //剪枝
        if(bills[0] != 5)
        {
            return false;
        }
        for(int i = 0; i < bills.size(); ++i)
        {
            if(bills[i] == 5)
            {
                cash_5++;
            }
            if(bills[i] == 10)
            {
                cash_10++;
                cash_5--;
            }
            if(bills[i] == 20)
            {
                if(cash_10 == 0)
                {
                    cash_20++;
                    cash_5 -= 3;
                }
                else
                {
                    cash_20++;
                    cash_10--;
                    cash_5--;
                }
            }
            if(cash_5 < 0 ||cash_10 < 0 || cash_20 < 0)
            {
                return false;
            }
        }
        return true;
    }
};
相关推荐
User_芊芊君子16 分钟前
【LeetCode经典题解】递归破解对称二叉树之谜
算法·leetcode·职场和发展
Rock_yzh17 分钟前
LeetCode算法刷题——49. 字母异位词分组
数据结构·c++·学习·算法·leetcode·职场和发展·哈希算法
小欣加油18 分钟前
leetcode 2654 使数组所有元素变成1的最少操作次数
数据结构·c++·算法·leetcode·职场和发展
Kt&Rs21 分钟前
11.12 LeetCode 题目汇总与解题思路
算法·leetcode
m0_5656111335 分钟前
Java Stream流操作全解析
java·开发语言·算法
大千AI助手42 分钟前
决策树悲观错误剪枝(PEP)详解:原理、实现与应用
人工智能·算法·决策树·机器学习·剪枝·大千ai助手·悲观错误剪枝
九年义务漏网鲨鱼1 小时前
【机器学习算法】面试中的ROC和AUC
算法·机器学习·面试
草莓熊Lotso1 小时前
《算法闯关指南:优选算法--位运算》--38.消失的两个数字
服务器·c++·算法·1024程序员节
剪一朵云爱着7 小时前
力扣81. 搜索旋转排序数组 II
算法·leetcode·职场和发展
报错小能手9 小时前
刷题日常 5 二叉树最大深度
算法