贪心算法|【简介】

写在前面:

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

什么是贪心算法?

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

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;

相关推荐
十盒半价12 分钟前
从递归到动态规划:手把手教你玩转算法三剑客
javascript·算法·trae
GEEK零零七18 分钟前
Leetcode 1070. 产品销售分析 III
sql·算法·leetcode
凌肖战26 分钟前
力扣网编程274题:H指数之普通解法(中等)
算法·leetcode
秋说27 分钟前
【PTA数据结构 | C语言版】将数组中元素反转存放
c语言·数据结构·算法
WebInfra27 分钟前
如何在程序中嵌入有大量字符串的 HashMap
算法·设计模式·架构
森焱森1 小时前
APM与ChibiOS系统
c语言·单片机·算法·架构·无人机
★Orange★2 小时前
Linux Kernel kfifo 实现和巧妙设计
linux·运维·算法
尘世闲鱼2 小时前
解数独(C++版本)
开发语言·c++·算法·解数独
qqxhb2 小时前
零基础数据结构与算法——第四章:基础算法-排序(中)
数据结构·算法·排序算法·归并·快排·堆排
Y1nhl3 小时前
力扣_链表_python版本
开发语言·python·算法·leetcode·链表·职场和发展