860. 柠檬水找零
在柠檬水摊上,每一杯柠檬水的售价为 5 美元。
顾客排队购买你的产品,(按账单 bills 支付的顺序)一次购买一杯。
每位顾客只买一杯柠檬水,然后向你付 5 美元、10 美元或 20 美元。你必须给每个顾客正确找零,也就是说净交易是每位顾客向你支付 5 美元。
注意,一开始你手头没有任何零钱。
如果你能给每位顾客正确找零,返回 true ,否则返回 false 。
示例 1:
输入:[5,5,5,10,20]
输出:true
解释:
前 3 位顾客那里,我们按顺序收取 3 张 5 美元的钞票。
第 4 位顾客那里,我们收取一张 10 美元的钞票,并返还 5 美元。
第 5 位顾客那里,我们找还一张 10 美元的钞票和一张 5 美元的钞票。
由于所有客户都得到了正确的找零,所以我们输出 true。
示例 2:
输入:[5,5,10]
输出:true
示例 3:
输入:[10,10]
输出:false
示例 4:
输入:[5,5,10,10,20]
输出:false
解释:
前 2 位顾客那里,我们按顺序收取 2 张 5 美元的钞票。
对于接下来的 2 位顾客,我们收取一张 10 美元的钞票,然后返还 5 美元。
对于最后一位顾客,我们无法退回 15 美元,因为我们现在只有两张 10 美元的钞票。
由于不是每位顾客都得到了正确的找零,所以答案是 false。
提示:
0 <= bills.length <= 10000
bills[i] 不是 5 就是 10 或是 20
1 解法1:16 ms 9.6 MB 2 class Solution { 3 public: 4 bool lemonadeChange(vector<int>& bills) { 5 //思路: 6 //对账单顺序遍历,若是5元,直接收取,不用找零 7 //若不是5元,那么需要对其找零,若能找开,true 否则false 8 //还是需要记录5元的10元的,20元的面值 个数,根据个数,贪心找 9 int sum=0;//初始化为0,没有任何钱 10 int data[3]={0};//0代表5 元,1 代表10元 ,2代表20元 11 for(int i=0;i<bills.size();i++){//遍历账单 12 if(bills[i]==5){//是5元,零钱+5 13 sum+=5; 14 data[0]++; 15 } 16 else { 17 bills[i]==10?data[1]++:data[2]++; 18 int rest=bills[i]-5;//需要找的钱 19 int mon=0; 20 for(int j=1;j>=0;j--){//我们只找 20-5 ,和10-5的 21 if(rest==0) break; 22 j==1?mon=10:mon=5; 23 while(data[j]>0&&rest-mon>=0){//若是大于这个面值,可以用这个找钱,且有这个零钱 24 data[j]--;//零钱个数减一个 25 rest-=mon;//要找的钱 减去这个面值 (贪心) 26 } 27 } 28 if(rest>0) return false;//没找完,返回false 29 } 30 } 31 return true;//找得开 32 } 33 };
1 解法2: 16 ms 9.6 MB 2 3 class Solution { 4 public: 5 bool lemonadeChange(vector<int>& bills) { 6 //思路: 7 //对账单顺序遍历,若是5元,直接收取,不用找零 8 //若不是5元,那么需要对其找零,若能找开,true 否则false 9 //还是需要记录5元的10元的,20元的面值 个数,根据个数,贪心找 10 //初始化为0,没有任何钱 11 map<int,int,greater<int> > mp;//从大到小排序map 按键 12 mp[10]=0,mp[5]=0,mp[20]=0; 13 for(int i=0;i<bills.size();i++){//遍历账单 14 if(bills[i]==5){//5元零钱个数+1 15 mp[5]++; 16 } 17 else { 18 mp[bills[i]]++;//10 或20元个数加1 19 int rest=bills[i]-5;//需要找的钱(开始贪心) 20 for(auto& iter:mp){//从大到小遍历 20 -10- 5 21 while(iter.second>0&&rest-iter.first>=0){//若是大于这个面值,可以用这个找钱,且有这个零钱 22 iter.second--;//零钱个数减一个 23 rest-=iter.first;//要找的钱 减去这个面值 24 } 25 } 26 if(rest>0) return false;//没找完,返回false 27 } 28 } 29 return true;//找得开 30 } 31 };