leetcode 860 柠檬水找零

一、题目描述

二、解题思路

整体思路

可以采用哈希表+模拟来解决这个问题,哈希表用于记录手中5、10面额的钱的数量,模拟这个结账的过程。

具体思路

(1)hash向量用于记录手中5、10面额的钱的数量,用于模拟哈希表,由于只需要记录两种面额钱的出现次数,所以将长度初始化为3,元素为0;

(2)遍历bills数组:

<1>如果当前的客人持有的是5美元,就执行hash[1]++;

<2>如果当前的客人持有的是10美元,如果有手上有5美元,就进行找零,continue。如果手上没有5美元,表示无法找零,返回false;

<3>如果当前的客人持有的是20美元,优先用一张10一张5进行找零,然后是3张5美元找零,如果都不能找零,就返回false;

(3)若可以将循环执行完,表示可以完成找零,返回true;

三、代码实现

cpp 复制代码
class Solution {
public:
    bool lemonadeChange(vector<int>& bills) {
        //哈希表+模拟
        //数组模拟哈希表
        vector<int> hash(3,0);
        for(auto b:bills){
            if(b==5) hash[1]++;
            if(b==10){
                if(hash[1]==0) return false;
                else{
                    hash[1]--;
                    hash[2]++;
                }
            }
            if(b==20){
                //找零10和5美元
                if(hash[2]>=1&&hash[1]>=1){
                    hash[2]--;
                    hash[1]--;
                    continue;
                }
                //找零3个5美元
                if(hash[1]>=3){
                    hash[1]-=3;
                    continue;
                }
                return false;
            }
        }
        return true;
    }
};
相关推荐
Dream it possible!26 分钟前
LeetCode 面试经典 150_图的广度优先搜索_最小基因变化(93_433_C++_中等)(广度优先搜索(BFS))
c++·leetcode·面试·广度优先
CoovallyAIHub1 小时前
何必先OCR再LLM?视觉语言模型直接读图,让百页长文档信息不丢失
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
NAN-DETR:集中式噪声机制如何让检测更“团结”?
深度学习·算法·计算机视觉
CoovallyAIHub1 小时前
火箭工程大学多模态遥感检测新框架MROD-YOLO:如何将小目标检测精度提升至77.9%?
深度学习·算法·计算机视觉
steins_甲乙1 小时前
C++并发编程
开发语言·c++
CoovallyAIHub2 小时前
未来物体检测趋势:需要关注的 7 个关键问题
深度学习·算法·计算机视觉
业精于勤的牙2 小时前
小张刷题计划(二)
数据结构·算法
谈笑也风生2 小时前
期望个数统计(二)
算法
hans汉斯2 小时前
【人工智能与机器人研究】人工智能算法伦理风险的适应性治理研究——基于浙江实践与欧美经验的整合框架
大数据·人工智能·算法·机器人·数据安全·算法伦理·制度保障
CoderYanger2 小时前
动态规划算法-两个数组的dp(含字符串数组):42.不相交的线
java·算法·leetcode·动态规划·1024程序员节