柠檬水找零【贪心1】

由于是贪心算法的第一道题,所以先介绍一下贪心算法。

贪心策略:一种解决问题的策略,局部最优->全局最优。(贪婪+鼠目寸光)

1、把解决问题的过程分为若干步

2、解决每一步时,都选择当前看起来最优的解法。

3、"希望"得到全局最优解。

特点:

没有模版,只能是积累经验,心态放平。

贪心算法的正确性需要证明。

柠檬水找零

题目

代码

cpp 复制代码
class Solution {
public:
    bool lemonadeChange(vector<int>& bills) {
        int n = bills.size();
        int five_nums = 0,ten_nums = 0;
        for(int i = 0;i < n;i++){
            if(bills[i] == 5)
            {
                five_nums++;
            }
            else if(bills[i] == 10)
            {
                if(five_nums == 0) return false;
                five_nums--;
                ten_nums++;
            }
            else
            {
                if(ten_nums && five_nums)
                {
                    ten_nums--;
                    five_nums--;
                }
                else if(five_nums >= 3)
                {
                    five_nums -= 3;
                }
                else return false;
            }
        }
        return true;
    }
};

证明

相关推荐
李余博睿(新疆)10 小时前
c++经典练习题-分支练习(2)
c++·算法
Dev7z10 小时前
基于中心先验的全局对比度显著性检测算法
人工智能·算法·计算机视觉
重生之我是Java开发战士10 小时前
【算法日记】排序算法:原理、实现、性能与应用
数据结构·算法·排序算法
啊阿狸不会拉杆11 小时前
《数字图像处理》第 5 章-图像复原与重建
图像处理·人工智能·算法·matlab·数字图像处理
断剑zou天涯11 小时前
【算法笔记】资源限制类题目的解题套路
笔记·算法·哈希算法
元亓亓亓11 小时前
LeetCode热题100--763. 划分字母区间--中等
算法·leetcode·职场和发展
鹿角片ljp11 小时前
力扣206.反转链表-双指针法(推荐)
算法·leetcode·链表
智航GIS11 小时前
ArcGIS大师之路500技---037普通克里金VS泛克里金
人工智能·算法·arcgis
晨晖211 小时前
循环队列:出队
算法
LYFlied11 小时前
【每日算法】LeetCode 70. 爬楼梯:从递归到动态规划的思维演进
算法·leetcode·面试·职场和发展·动态规划