贪心算法|【简介】

写在前面:

贪心算法是要持续去学习的,其他算法学完之后,就可以做别的题,而贪心算法不是,需要一直去学习,碰见新的题型很正常。

什么是贪心算法?

贪心算法是解决问题的策略,也就是解决问题的方法。这个方法就是利用局部最优的方法推出全局最优

1.把解决问题的方法分成若干步。然后分布去解决问题。

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

3."希望"得到全局最优解

看见这三步的时候,我会有两个问题,

1.怎么选择当前看起来"最优的"解法。

2.为什么是"希望"得到全局最优解,而不是得到全局最优解

接下来举例子

1.找零钱问题

我们现在是老板,假设我们有无限个面值为20,10,5,1的纸币,现在要求我们用最少的张数的纸币去找零。

顾客用50块钱来买4块钱的东西,我们需要找零46.

找零的时候我们肯定是一步一步给你找零钱,这个一步一步找零钱也就相当于我们的第一步将这个问题分成若干个小问题。第二步是,要选择当前看起来"最优的"解法。,就是要用最快凑够这46块钱,因此最优解法,应该是用小于当前钱数的最大的面值去找零

第一步,46,用最大的面值用来找零,也就是20的面值来找钱,剩下26;

第二步, 剩下26 ,还是用最大的面值用来找零,也就是20的面值,剩下6;

第三步,剩下6,用最大的面值的用来找零,5的面值,剩下1;

第四步,剩下1,用最大的面值用来找零,1的面值,剩下0;

相关推荐
罗西的思考3 小时前
【Agent】MemOS 源码笔记---(5)---记忆分类
人工智能·深度学习·算法
qq_433554546 小时前
C++数位DP
c++·算法·图论
AshinGau6 小时前
Softmax 与 交叉熵损失
神经网络·算法
似水এ᭄往昔6 小时前
【C++】--AVL树的认识和实现
开发语言·数据结构·c++·算法·stl
栀秋6666 小时前
“无重复字符的最长子串”:从O(n²)哈希优化到滑动窗口封神,再到DP降维打击!
前端·javascript·算法
xhxxx6 小时前
不用 Set,只用两个布尔值:如何用标志位将矩阵置零的空间复杂度压到 O(1)
javascript·算法·面试
有意义6 小时前
斐波那契数列:从递归到优化的完整指南
javascript·算法·面试
charlie1145141917 小时前
编写INI Parser 测试完整指南 - 从零开始
开发语言·c++·笔记·学习·算法·单元测试·测试
mmz12077 小时前
前缀和问题2(c++)
c++·算法
TL滕7 小时前
从0开始学算法——第十六天(双指针算法)
数据结构·笔记·学习·算法