leetcode 贪心_贪心算法:给我最好的,现在就要!

bd6c3b256e9ead7e5329ada40a7c47f8.png

每次做选择的时候都做出当下最好的选择,而不考虑将来的后果。并且期望最终得到的结果是全局最优的。

——贪心算法 - Greedy Algorithm

什么时候该使用贪心算法

针对一组数据,定义了限制值。现在需要我们从中选出几个数据,在满足限制值的情况下,使期望值最大

这个不难理解,比如知乎上这个很火的问题:如果带着一百万人民币回到1997年,你会做什么投资? 对于这个问题,一百万和1997年就是限制值,你在这个条件下可选的各种投资方案就是上面说的“一组数据”,要做的就是经过我们的运作将收益最大化(使期望值最大)。很明显贪心的我们会优先选择低成本而高回报的项目。

使用贪心算法的例子

  • 分糖果
  • 无重叠区间
  • 钱币找零

分糖果

我们要把m个大小不同的糖果分给n个贪婪不一的孩子,糖果的大小大于或等于孩子的满足感时才能满足这个孩子,怎样才能满足让尽量多孩子满足?

在这个例子中,限制了糖果的数量,并期望满足尽量多孩子,这就要求我们运用恰当的方式来选出尽量多的孩子。小孩子是天真的,成年人是贪心的。只需要用刚好能满足孩子的糖果就能使他满足,我们就分小糖果给满足感低的孩子,大糖果可以用来满足满足度高的孩子,这样就可以满足尽量多的孩子。所以我们的做法是:挑出满足度最低的孩子,给他最小的能满足他的糖果,重复这个操作直到糖果分完。

LeetCode#455. 分发饼干:Assign cookies

    public int findContentChildren(int[] g, int[] s) {Arrays.sort(g); // 将孩子的满足度从小到大排序Arrays.sort(s); // 将糖果的大小从小到大排序int gi = 0, si = 0;while(gi < g.length && si < s.length){if(g[gi] <= s[si]){gi++; // 当前小孩子得到满足,就换下一个孩子}si++; // 当前的糖果分出去就换下一个糖果;没有分出去就说明这个糖果太小没人要,也得换下一个糖果}return gi;}

无重叠区间

给定n个区间和每个区间的起始与结束坐标,这些区间可能存在重叠的情况,我们要移除掉一些区间以使剩下的区间不重叠,最少要移除多少个区间?

假设给定一组区间为:[[6, 8], [2, 4], [3, 5], [1, 5], [5, 9], [8, 10]],求最少需要移除多少个区间。为了保留更多区间,保留下来的区间就应该尽量下且互相不重叠。我们先将所有区间按照结束位置end来排序,由于排序之后end越小的区间的位置就更靠左,留给右边的位置也越多,就能选择出更多的区间。如此一来,只要将排序后的区间遍历一遍,如果当前区间的开始位置小于前一个区间的结束位置,就说明产生了重叠应该移除掉;否则就是应该保留的区间。

477add4319f12a82b0d018d87933c812.png
排序后的区间

LeetCode#435. 无重叠区间:Non-overlapping Intervals

class Solution {public int eraseOverlapIntervals(int[][] intervals) {if(intervals == null || intervals.length < 1) return 0;int cnt = 0;// 先按每个区间的end排序Arrays.sort(intervals, new MyComparator());int end = intervals[0][1];for(int i = 1; i < intervals.length; i++){// 如果当前得start 小于之前的 end,就说明有重合,需要移除。则计数并跳过本次循环if(intervals[i][0] < end){cnt++;}else{end = intervals[i][1];}}return cnt;}class MyComparator implements Comparator<int[]>{@Overridepublic int compare(int[] a, int[] b){return a[1] - b[1];}}
}

钱币找零

这是个很贴近日常生活的例子。假如我们有面值为1、5、10、50、100的纸币若干,它们的张数分别为c1、c5、c10、c50、c100。现在我们需要支付K元,最少需要多少张纸币呢?

在支付额K恒定时,要想付出更少的纸币数量,就要优先使用大面值来支付。限定值是金额K,而期望是付出最少纸币数量。假设买了一个烤冷面,需要398元。先从包里数三张100的红票票,此时还差98元;再来一张50的,还差48;二十元的面值不流通了,我们只好拿出4张10元的;最后是一张5元和4张1元烤冷面就到手了。当然还有一个问题是我们的纸币数量有限,如果我们没有三张100元,就要提前让50元登场。这个问题你理解了吗?没理解也没关系,请出示你的付款码,我扫你。

小结

其实在能用贪心算法的场景中,贪心都是能得到最优解的。在数学上也是可以证明最优解的有效性的。贪心算法适用的场景就那些,只要多多练习当你再次碰见这些场景时就能游刃有余得想出解题思路了。

知乎用户​www.zhihu.com

贪心算法的应用

  • 对数据压缩编码的霍夫曼编码(Huffman Coding)
  • 求最小生成树的Prim算法和Kruskal算法
  • 求单源最短路径的Dijkstra算法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/500867.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java导致native非法指令,Java代码引起的NATIVE野指针问题(上)

朴英敏&#xff0c;小米MIUI部门。从事嵌入式开发和调试工作8年多&#xff0c;擅长逆向分析方法&#xff0c;主要负责解决安卓系统稳定性问题。上周音乐组同事反馈了一个必现Native Crash问题&#xff0c;tombstone如下&#xff1a; pid: 5028, tid: 5028, name: com.miui.play…

axure怎么做5秒倒计时_罗胖60秒:怎么做一个课程?

今天是罗胖陪伴你的第 2714 天1. 我们在研发课程的时候&#xff0c;有一个很关键的方法&#xff0c;我们内部称之为叫“不是而是”大法。2. 什么意思呢&#xff1f;就是如果你只告诉别人它是什么&#xff0c;那等于啥都没说。比如&#xff0c;我告诉你要经营好一家小店&#xf…

php7 变量,PHP7变量结构分析

PHP7相对于PHP5提升了将近一倍的性能&#xff0c;下面我将针对PHP7与PHP5的变量结构实现进行对比&#xff0c;分析为什么PHP7性能提升。当然变量结构修改只是PHP7性能提升中的一部分原因&#xff0c;还有很多原因比如HashTable结构变更、减少内存分配次数、多使用栈内存等等&am…

点在不规则图形内算法python_目标检测算法中规则矩形和不规则四边形IOU的Python实现...

交并比(Intersection-over-Union&#xff0c;IoU)&#xff0c;目标检测中使用的一个概念&#xff0c;我们在进行目标检测算法测试时&#xff0c;重要的指标&#xff0c;是产生的预测框(candidate bound)与标记框(ground truth bound)的交叠率&#xff0c;即它们的交集与并集的比…

树莓派跑php,在树莓派4上部署nginx+php

本试验是基于树莓派的 buster 版本。一、安装 nginxapt install nginx -y完成安装之后&#xff0c;可以使用 dpkg -l | grep nginx 找到相关的安装包&#xff1a;通过分析 /var/lib/dpkg/status 可以得到 nginx 安装包的依赖关系&#xff1a;nginx --> nginx-full --> li…

只有python可以爬虫吗_无所不能的Python之爬虫那点事儿

今天给大家介绍一个有趣的新技术——爬虫。首先来讲一下啥是爬虫。爬虫也叫网络爬虫&#xff0c;是一种按照一定的规则&#xff0c;自动地抓取万维网信息的程序或者脚本。通俗的来讲&#xff0c;爬虫就是一段程序&#xff0c;它来根据你的设定自己去互联网上浏览网页并把这些信…

java排队系统模型,MMC排队系统模型

MMC排队系统模型及应用M/M/C排队模型及其应用摘要&#xff1a;将随机服务系统中M/M/C排队模型应用到理发服务行业中。通过对某理发店进行调查&#xff0c;以10min为一个调查单位调查顾客到达数&#xff0c;统计了72个调查单位的数据&#xff0c;又随机调查了113名顾客服务时间&…

php 如何生成微信小程序,微信小程序一键生成平台系统/一键生成小程序开源小程序PHP|ThinkPHP平台源码下载...

源码名称&#xff1a;微信小程序一键生成平台系统/一键生成小程序开源小程序PHP|ThinkPHP平台源码下载购买须知&#xff1a;(请仔细阅读了解)【1】源码一律经测试无误。【2】不提供任何修改和编辑服务&#xff0c;不包安装调试&#xff0c;假如你什么都不懂的请不要拍。【3】假…

python excel格式刷_Excel格式刷怎么用?没你想的那么简单,你知道几种用法?

【温馨提示】亲爱的朋友&#xff0c;阅读之前请您点击【关注】&#xff0c;您的支持将是我最大的动力&#xff01;Excel使用过程中&#xff0c;格式刷相信小伙伴们都知道&#xff0c;平常也没少用。Excel中格式刷可以帮助我们快速的复制单元格的格式&#xff0c;而不用再重新设…

php接受post接受不到数据,PHP $_POST接受不到数据,但$_GET可以接受数据

"HTML ajax端 $.ajax({ url:/login.php, data:{name:name, pwd:pwd}, type:POST, dataType:json, success:function(data){ console.dir(data) if(data.status 1) alert(data.mes) }else{ alert(data.mes) } } })php端&#xff1a;$sql "SELECT * FROM user WHERE …

python安装多个版本_Mac安装多个python版本

Mac安装多个python版本步骤如下&#xff1a;1、安装pyenv$sudo brew install pyenv然后在 .bash_profile 文件中添加命令&#xff1a;vi .bash_profile添加&#xff1a;eval "$(pyenv init -)"最后&#xff0c;更新一下环境变量命令&#xff1a;source .bash_profile…

java .item,javabb-javaitem-cloud

JavaItem-Cloud项目介绍JavaItem-Cloud是一个新开发的微服务架构平台&#xff0c;基于最新流行的技术SpringBoot、SpringCloud & SpringCloud Alibaba、Vue、Vuex、ElementUI。系统特性后端使用当前流行技术&#xff0c;SpringBoot、SpringCloud、SpringCloud Alibaba、Myb…

软件使用手册模板_我的印象笔记使用手册(精简说明)

在之前的一文中&#xff0c;我已经详细写过我的印象笔记使用的方法了&#xff0c;这次呢&#xff0c;再做一个更新的使用情况和更清楚明了和精简的说明。不居竹&#xff1a;我的印象笔记使用手册​zhuanlan.zhihu.com文章目录&#xff1a;1、知识管理收集知识整理知识输出知识2…

java 响应事件,用java响应颜色事件

我正在构建一个java应用程序来解决难题 . 我编码的方式基本上是程序将采取屏幕截图&#xff0c;在屏幕截图中找到一个像素&#xff0c;并通过机器人功能将鼠标移动到桌面上的那个位置 . 我理解屏幕截图背后的理论&#xff0c;将其存储在一个数组中&#xff0c;探索数组直到一个…

怎样保存python源程序_五分钟教会你如何编写、保存与运行 Python 程序

第一步接下来我们将看见如何在 Python 中运行一个传统的“Hello World”程序。Python教程本章将会教你如何编写、保存与运行 Python 程序。通过 Python 来运行的你的程序有两种方法——使用交互式解释器提示符或直接运行一个源代码文件。我们将了解如何使用他们二者的功能。使用…

matlab实验8数据分析与多项式计算,hashidamatlab实验八数据处理与多项式计算.doc

实验八电子二班张秀云 一、实验目的〔据处理与多项式计算1、掌握数据统计和分析的方法2、掌握数值插值与曲线拟合的方法及其应用3、掌握多项式的常用运算二、实验内容1、利用MATLAB提供的rand函数生成30000个符合均匀分布的随机 数&#xff0c;然后检验随机数的性质&#xff1a…

微信群定时发消息 python_Python实现每天定时发微信问候语

IT学习乐园甄选优质技术文档&#xff0c;服务群众&#xff01;作者&#xff1a;varlemon来源&#xff1a;https://www.cnblogs.com/connect/p/python-wechat-iciba.html图源&#xff1a;网络编辑&#xff1a;IT技术头条免责声明&#xff1a;1.本公众号所转载文章均来自公开网络…

php页面添加链接,怎么给一个PHP密码访问页面加超链接

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼$password "1234"; // 这里是密码$p "";if(isset($_COOKIE["isview"]) and $_COOKIE["isview"] $password){$isview true;}else{if(isset($_POST["pwd"])){if($_POST["…

python 硬件模拟_如何编写一个硬件模拟器?

当下是短视频的时代&#xff0c;随着5g进程的加速推动&#xff0c;短视频已经成为了很多自媒体人变现的主要途径B站&#xff0c;抖音&#xff0c;快手&#xff0c;西瓜视频等等各大平台都砸钱鼓励平台创作者创作视频&#xff0c;因为平台流量大&#xff0c;我们就可以通过一些技…

通信之道从微积分到5gpdf_保送清华成博士,华为12年搞通信,他为何如此看待 5G ?| 人物志...

作者 | 伍杏玲 胡巍巍出品 | CSDN(ID&#xff1a;CSDNnews)一位通信专家&#xff0c;清华读了博士&#xff0c;北大从事博士后研究工作&#xff0c;但却只有12年工作经历&#xff1f;明明家里几套房&#xff0c;却热爱骑车出行&#xff1f;他是&#xff1f;他是国内小有名气的通…