贪心算法|【简介】

写在前面:

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

什么是贪心算法?

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

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;

相关推荐
C雨后彩虹5 分钟前
无向图染色
java·数据结构·算法·华为·面试
坚持就完事了12 分钟前
扫描线算法
算法
鱼跃鹰飞15 分钟前
Leetcode尊享面试100题:252. 会议室
算法·leetcode·面试
程序员-King.15 分钟前
二分查找——算法总结与教学指南
数据结构·算法
Zevalin爱灰灰17 分钟前
现代控制理论——第三章 线性控制系统的能控性和能观性
线性代数·算法·现代控制
kklovecode19 分钟前
C语言之头文件,宏和条件编译
c语言·开发语言·算法
Xの哲學30 分钟前
Linux自旋锁深度解析: 从设计思想到实战应用
linux·服务器·网络·数据结构·算法
晚风吹长发34 分钟前
深入理解Linux中用户缓冲区,文件系统及inode
linux·运维·算法·链接·缓冲区·inode
程序员-King.41 分钟前
day131—链表—反转链表Ⅱ(区域反转)(LeetCode-92)
leetcode·链表·贪心算法
cwplh43 分钟前
DP 优化一:单调队列优化 DP
算法