当前位置: 首页 > article >正文

算法刷题--贪心算法

要点

其实也没啥要点,就是求局部最优解,完事了将局部最优解汇总、筛选、max\min之类的,获得全局最优解,每一次都选择最优的,这个就是贪心算法。

例题

分发饼干-中等

大概就是一堆小孩g,每个人都有一个胃口g[i],这个值是ta,满足的值;我自己有一些饼干s,每个饼干都有一个值s[j],问在一个孩子只能吃一块饼干的情况下,最大能满足多少个孩子。
写着题我的思路就是,先满足胃口小的,给这俩数组都排序,吃了的就没了。计算吃了的数量

摆动序列-中等

给个数组,当数字每次两两之间的差值呈现一会正,一会负的时候,这个就叫做摆动序列,求最大摆动序列长度,可以删减其中的某些数字形成子串返回,
eg:

输入:nums = [1,17,5,10,13,15,10,5,16,8] 输出:7 解释:这个序列包含几个长度为 7 摆动序列。
其中一个是 [1, 17, 10, 13, 10, 16, 8] ,各元素之间的差值为 (16, -7, 3, -3, 6, -8) 。

那么我的做法就是细化局部,记录每一次上升下降为1和-1,相等就是0,最后返回1和-1的。
其实写这道题的时候,都没意识到,这个就是贪心算法

分发糖果-困难

很可恶了,有糖为什么扣扣搜的分!生气!!
题目说有一些孩子g,他们的分数分别是g[i],我们要根据他们的分数给他们糖果。
俩规则:

  1. 所有孩子都至少有一个糖
  2. 相邻两个孩子分数更高的拿的更高(PS:这里没说分数一样的应该怎么样,所以直接不比较,我当时看到这里很懵)

思路借助代码随想录,分为从前到后遍历比较右边的是否大于左边的,是就加一;
然后从后往前比较左边的是否大于右边的,是就加一。
这样局部最优,然后合起来全局最优。


http://www.kler.cn/a/582019.html

相关文章:

  • Sentinel-1 InSAR ISCE数据处理:stackSentinel.py 完全指南
  • python LLM工具包
  • API调试工具的无解困境:白名单、动态IP与平台设计问题
  • Faster R-CNN原理详解以及Pytorch实现模型训练与推理
  • Spring Boot 整合 RabbitMQ(在Spring项目中使用RabbitMQ)
  • Chrome 浏览器 134 版本新特性
  • 一周学会Flask3 Python Web开发-SQLAlchemy连接Mysql数据库
  • Html5-照片滤镜应用学习经验总结
  • Windows10下docker desktop命令行操作指南(大部分也适用于Linux)
  • Jmeter请求发送加密参数
  • K8S学习之基础二十三:k8s的持久化存储之nfs
  • 机器学习 Day02,matplotlib库绘图
  • TikTok多店铺网络安全搭建指南
  • 在资源有限中逆势突围:从抗战智谋到寒门高考的破局智慧
  • 数据库统计信息开启和关闭
  • 深入浅出Bearer Token:解析工作原理及其在Vue、Uni-app与Java中的实现Demo
  • Redis 设置密码(配置文件、docker容器、命令行3种场景)
  • HippoRAG 2 原理精读
  • Vue开发中计算属性与方法调用之间的区别与联系
  • LeNet-5卷积神经网络详解