-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlemonade-change.cpp
34 lines (33 loc) · 1.25 KB
/
lemonade-change.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
//Q. - At a lemonade stand, each lemonade costs $5. Customers are standing in a queue to buy from you and order one at a time (in the order specified by bills).
// Each customer will only buy one lemonade and pay with either a $5, $10, or $20 bill. You must provide the correct change to each customer so that the net transaction is that the customer pays $5.
// Note that you do not have any change in hand at first.
// Given an integer array bills where bills[i] is the bill the ith customer pays, return true if you can provide every customer with the correct change, or false otherwise.
class Solution {
public:
bool lemonadeChange(vector<int>& bills) {
int count5 = 0;
int count10 = 0;
int n = bills.size();
if(bills[0]!=5) return false;
for(int i=0;i<n;++i){
if(bills[i]==5){
++count5;
}
else if(bills[i]==10){
--count5;
++count10;
}
else{
if(count10>0){
--count10;
--count5;
}
else{
count5 = count5-3;
}
}
if(count5<0) return false;
}
return true;
}
};