题目
在柠檬水摊上,每一杯柠檬水的售价为 5 美元。顾客排队购买你的产品,(按账单 bills 支付的顺序)一次购买一杯。
每位顾客只买一杯柠檬水,然后向你付 5 美元、10 美元或 20 美元。你必须给每个顾客正确找零,也就是说净交易是每位顾客向你支付 5 美元。
注意,一开始你手头没有任何零钱。
给你一个整数数组 bills ,其中 bills[i] 是第 i 位顾客付的账。如果你能给每位顾客正确找零,返回 true ,否则返回 false 。
推荐思路
这个思路很好捏~不是本人
class Solution {
public:
bool lemonadeChange(vector<int>& bills) {
int n = bills.size();
unordered_map<int, int> mp;
mp[5] = 0;
mp[10] = 0;
mp[20] = 0;
for (int i = 0; i < n; ++i) {
if (bills[i] == 5)
mp[5]++;
else if (bills[i] == 10) {
if (mp[5] - 1 >= 0) {
mp[10]++;
mp[5]--;
}
else {
return false;
}
}
else if (bills[i] == 20) {
if (mp[10] >= 1 && mp[5] >= 1) {
mp[5]--;
mp[10]--;
mp[20]++;
}
else if (mp[5] >= 3) {
mp[20]++;
mp[5] = mp[5] - 3;
}
else {
return false;
}
}
}
return true;
}
};
只是推荐一下他人的方法,并无别意