219.贪心算法:柠檬水找零(力扣)

代码解决

cpp 复制代码
class Solution {
public:
    bool lemonadeChange(vector<int>& bills) 
    {
        int num5=0, num10=0; // 初始化5美元和10美元的计数器
        for(int i=0; i < bills.size(); i++) // 遍历所有账单
        {
            if(bills[i]==5) // 如果账单是5美元
            {
                num5++; // 增加5美元的计数
                continue; // 继续处理下一个账单
            }
            else if(bills[i]==10) // 如果账单是10美元
            {
                num10++; // 增加10美元的计数
                if(num5!=0) // 检查是否有5美元的零钱
                {
                    num5--; // 使用一个5美元的零钱
                    continue; // 继续处理下一个账单
                }
                else
                {
                    return false; // 没有足够的零钱,返回false
                }
            }
            else if(bills[i]==20) // 如果账单是20美元
            {
                if(num10!=0 && num5!=0) // 优先使用一个10美元和一个5美元的零钱
                {
                    num5--; // 使用一个5美元的零钱
                    num10--; // 使用一个10美元的零钱
                    continue; // 继续处理下一个账单
                }
                else if(num5>=3) // 如果没有10美元的零钱,检查是否有三个5美元的零钱
                {
                    num5 -= 3; // 使用三个5美元的零钱
                }
                else
                {
                    return false; // 没有足够的零钱,返回false
                }
            }
        }
        return true; // 如果所有账单都成功找零,返回true
    }
};

代码逻辑总结:

  1. 初始化两个计数器来记录5美元和10美元的数量。
  2. 遍历账单列表:
    • 如果账单是5美元,直接增加5美元的数量。
    • 如果账单是10美元,首先检查是否有5美元的零钱,如果有则使用一个5美元的零钱并增加10美元的数量,否则返回false。
    • 如果账单是20美元,优先尝试使用一个10美元和一个5美元的零钱,如果不行则尝试使用三个5美元的零钱,如果两种方式都不行则返回false。
  3. 遍历结束后,如果所有账单都成功找零,则返回true。
相关推荐
不会就选b12 分钟前
算法日常・每日刷题--<二分查找>1
算法
「維他檸檬茶」18 分钟前
大模型算法学习2026.6.13
学习·算法
叫我:松哥22 分钟前
基于Python的共享单车租赁数据分析与预测系统,技术栈flask+boostrap+随机森林+XGBoost
人工智能·python·深度学习·算法·随机森林·数据分析·flask
BAGAE34 分钟前
星链卫星数据获取:从太空安全到实时通信的技术革命
网络·数据结构·数据库·算法·云计算·hbase
happymaker062637 分钟前
LeetCodeHor100——438.找到字符串中所有的字母异位词
算法
西安邮电大学44 分钟前
有关栈的经典算法题
java·后端·其他·算法·面试
h_a_o777oah1 小时前
【算法专项】扩展域并查集:原理详解及解决大部分种类并查集问题(洛谷P5937 P2024 C++代码)
数据结构·c++·算法·acm·并查集·扩展域·逻辑建模
兰令水1 小时前
leecodecode【单调栈】【2026.6.12打卡-java版本】
java·开发语言·算法
TMT星球1 小时前
魔法原子上交会首秀VLA K02大模型,完成具身智能从“执行”到“理解”的能力跃迁
人工智能·算法·机器学习
2301_764441331 小时前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互