**
题目:
**
在柠檬水摊上,每一杯柠檬水的售价为 5 美元。顾客排队购买你的产品,(按账单 bills 支付的顺序)一次购买一杯。
每位顾客只买一杯柠檬水,然后向你付 55美元、10 美元或 220 美元。你必须给每个顾客正确找零,也就是说净交易是每位顾客向你支付 5 美元。
注意,一开始你手头没有任何零钱。
给你一个整数数组bills,其中bills[i] 是第i 位顾客付的账。如果你能给每位顾客正确找零,输出 true,否则输出 false。
输入:5 5 5 10 20
输出:True
输入:5 5 10 10 20
输出:False
完整代码:
#include <iostream>
#include<vector>
using namespace std;
int main()
{
vector<int> bills;
int i;
while (cin >> i)
{
bills.push_back(i);
if (cin.get() == '\n') break;
}
int five = 0, ten = 0;
int f=1;
for (int i = 0; i < bills.size(); i++)
{
if (bills[i] == 5) five++;
else if (bills[i] == 10)
{
if (!five) {
f = 0;
break;
}
else {
five--;
ten++;
}
}
else
{
if (ten && five)
{
ten--;
five--;
}
else if (five < 3) {
f = 0;
break;
}
else if (five >= 3)
five -= 3;
}
}
if (f == 0) cout << "false" << endl;
else cout << "true" << endl;
return 0;
}