【LeetCode 刷题】贪心算法(2)-进阶

ops/2025/2/6 15:27:38/

此博客为《代码随想录》二叉树章节的学习笔记,主要内容为算法>贪心算法进阶的相关题目解析。

文章目录

  • 135. 分发糖果
  • 406. 根据身高重建队列
  • 134. 加油站
  • 968. 监控二叉树

135. 分发糖果

题目链接

python">class Solution:def candy(self, ratings: List[int]) -> int:n = len(ratings)left = [1] * nfor i in range(1, n):if ratings[i] > ratings[i-1]:left[i] = left[i-1] + 1right = [1] * nres = left[n-1]for i in range(n - 2, -1, -1):if ratings[i] > ratings[i+1]:right[i] = right[i+1] + 1res += max(left[i], right[i])return res
  • 将同时考虑两侧的元素分解为左右两个规则:
    • 左规则:只考虑当前元素和其左侧的元素,使其满足题目要求
    • 右规则:只考虑当前元素和其右侧的元素,使其满足题目要求
  • 先从左至右遍历,获得满足左规则的序列;再从右至左遍历,获得满足右规则的序列;最后每个位置取两序列的最大值,累加即为答案

406. 根据身高重建队列

题目链接

python">class Solution:def reconstructQueue(self, people: List[List[int]]) -> List[List[int]]:people.sort(key=lambda x: (-x[0], x[1]))res = []for p in people:if p[1] < len(res):res.insert(p[1], p)else:res.append(p)return res
  • 先按照身高降序排序,然后按照排位升序排序,按照排序后的数组顺序处理,根据当前元素的排位在结果序列中动态插队(因为按身高降序排列后,比当前元素高的元素都已经被处理过且放入 res 中,而后续未处理的元素又比当前元素矮,不影响结果)

134. 加油站

题目链接

python">class Solution:def canCompleteCircuit(self, gas: List[int], cost: List[int]) -> int:cur_gas, sum_gas = 0, 0res = 0for i in range(len(gas)):cur_gas += gas[i] - cost[i]sum_gas += gas[i] - cost[i]if cur_gas < 0:res = i + 1cur_gas = 0return res if sum_gas >= 0 else -1
  • 从 0 号站点开始累加,一旦 cur_sum 小于零,则表示之前所有的站点都不可能作为起点,选择下一个位置作为新的起点,cur_sum 重新开始累加
  • sum_gas 在遍历过程中累计全程所有的油量,如果 sum_gas < 0 则表示不可能开完一圈,返回 -1。

968. 监控二叉树

题目链接

python">class Solution:def minCameraCover(self, root: Optional[TreeNode]) -> int:# 0 无覆盖 1 有覆盖 2 有摄像头def traversal(node: Optional[TreeNode]) -> int:if not node:return 1left = traversal(node.left)right = traversal(node.right)if left == 1 and right == 1:return 0if left == 0 or right == 0:nonlocal resres += 1return 2if left == 2 or right == 2:return 1res = 0val = traversal(root)if val == 0: res += 1  # 根结点无覆盖return res
  • 贪心准则:尽可能不要让覆盖的范围重合
  • 设置三个节点的状态:0 无覆盖;1 有覆盖;2 有摄像头
    • 两个子节点有任何一个为无覆盖的状态,则当前节点需要放置摄像头
    • 两个子节点有任何一个有摄像头,则当前节点为有覆盖状态
    • 两个子节点都有覆盖(说明是孙子节点的摄像头),则当前节点为无覆盖
  • 根据贪心准则,叶子结点是不需要放置摄像头的,因此将空节点返回的状态值设置为 1 有覆盖,这样叶子结点的状态值则为 0 无覆盖,满足算法要求
  • 最后判断根节点的状态,如果为无覆盖,则需要额外再放一个摄像头

http://www.ppmy.cn/ops/156181.html

相关文章

提示词实践总结

目录 一、要求创建SqlServer表&#xff08;ChatGpt&#xff09; 二、要求生成多层架构代码&#xff08;Cursor&#xff09; 三、要求修改方法返回值类型&#xff08;Cursor&#xff09; 四、要求修改方法入参&#xff08;Cursor&#xff09; 五、复杂的多表关联生成&#…

实验十四 EL和JSTL

实验十四 EL和JSTL 一、实验目的 1、掌握EL表达式的使用 2、掌握JSTL的使用 二、实验过程 1、在数据库Book中建立表Tbook&#xff0c;包含图书ID&#xff0c;图书名称&#xff0c;图书价格。实现在bookQuery.jsp页面中模糊查询图书&#xff0c;如果图书的价格在50元以上&#…

AI回答 | spring,springboot,spring MVC,servlet, spring web之间的联系与支持

我的问题是&#xff1a;spring&#xff0c;springboot&#xff0c;spring MVC&#xff0c;servlet, spring web之间的联系与支持&#xff1f;我希望知道这些技术之间的演变、来龙去脉。如果中间穿插着关联的技术也请告诉我。【通过AI我理解到这是个spring生态问题&#xff0c;我…

Vim的基础命令

移动光标 H(左) J(上) K(下) L(右) $ 表示移动到光标所在行的行尾&#xff0c; ^ 表示移动到光标所在行的行首的第一个非空白字符。 0 表示移动到光标所在行的行首。 W 光标向前跳转一个单词 w光标向前跳转一个单词 B光标向后跳转一个单词 b光标向后跳转一个单词 G 移动光标到…

Ansible在多台服务器上运行python脚本

使用 Ansible 在多台服务器上批量运行 Python 脚本是一种高效且可靠的方式。以下是具体的实现步骤和示例代码&#xff1a; --- ### 1. 准备工作 - **安装 Ansible**&#xff1a;确保您的 Ansible 控制节点已安装 Ansible。如果没有安装&#xff0c;可以通过以下命令安装&#x…

PVE 中 Debian 虚拟机崩溃后,硬盘数据怎么恢复

问题 在 PVE 中给 Debian 虚拟机新分配硬盘后&#xff0c;通过 Debian 虚拟机开启 Samba 共享该硬盘。如果这个 Debian 虚拟机崩溃后&#xff0c;怎么恢复 Samba 共享硬盘数据。 方法 开启 Samba 共享相关知识&#xff1a;挂载硬盘和开启Samba共享。 新建一个虚拟机&#xf…

CH340G上传程序到ESP8266-01(S)模块

文章目录 概要ESP8266模块外形尺寸模块原理图模块引脚功能 CH340G模块外形及其引脚模块引脚功能USB TO TTL引脚 程序上传接线Arduino IDE 安装ESP8266开发板Arduino IDE 开发板上传失败上传成功 正常工作 概要 使用USB TO TTL&#xff08;CH340G&#xff09;将Arduino将程序上传…

如何使用C#的using语句释放资源?什么是IDisposable接口?与垃圾回收有什么关系?

在 C# 中,using语句用于自动释放实现了IDisposable接口的对象所占用的非托管资源,如文件句柄、数据库连接、图形句柄等。其使用方式如下: 基础用法 声明并初始化资源对象:在using关键字后的括号内声明并初始化一个实现了IDisposable接口的对象。使用资源:在using语句块内…