leetcode 860 柠檬水找零

一、题目描述

二、解题思路

整体思路

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

具体思路

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

(2)遍历bills数组:

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

<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;
    }
};
相关推荐
xieliyu.20 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
一条小锦吕*20 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
如竟没有火炬1 天前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵
8Qi81 天前
LeetCode 1143 & 718:最长公共子序列 / 最长重复子数组
算法·leetcode·职场和发展·动态规划
绿算技术1 天前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
Qt程序员1 天前
Linux RCU 原理与应用
linux·c++·内核·linux内核·rcu
想吃火锅10051 天前
【leetcode】1.两数之和js版
javascript·算法·leetcode
qeen871 天前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习
net3m331 天前
一阶软件低通滤波器算法
人工智能·算法