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

Day20:贪心算法,跳跃游戏

1.55跳跃游戏

维护当前可达最远距离

  1. 如果i超过了当前可达最远距离,无法达到终点
  2. 当当前可达最远距离大于等于终点时,说明可达终点
class Solution: def canJump(self, nums: List[int]) -> bool: max_jump = 0 for i in range(len(nums)): if i > max_jump: return False max_jump = max(i + nums[i], max_jump) if max_jump >= len(nums)-1: return True return False

2.45跳跃游戏

返回到达n-1的最小跳跃次数。测试用例保证可以到达n-1

  1. 维护三个变量,跳跃次数,已访问的可达最远位置,当前能跳跃的最远距离

  2. cur_reach和max_reach的区别

  3. jumps不是在起跳时+1,程序不知道起跳点在哪,只是在必须要跳跃(超过当前跳跃边界)时才跳跃,故cur_reach不是起跳点!!

    1. ​​​​jumps += 1不是"记录起跳",而是"记录必须进行一次新跳跃"

    2. 真正的起跳点可能是当前边界内的任意位置

    3. 算法通过farthest隐式选择了最优起跳点/降落点

    4. 不关心从哪里跳,只关心跳几次

  4. 循环范围[0,n-2]:程序保证了一定能到达n-1,故在最后一个值前就确定了最后一跳,最后一个值是目标,而不是决定要不要起跳

class Solution: def jump(self, nums: List[int]) -> int: n = len(nums) max_reach = 0 jumps = 0 cur_reach = 0 for i in range(n-1): max_reach = max(max_reach, nums[i]+i) if i == cur_reach: jumps += 1 cur_reach = max_reach return jumps

3.1005. K 次取反后最大化的数组和

我的错误:应该遍历k,k为0才结束,而我遍历数组,没有考虑到当所有的负数都变成整数且k还有剩余的情况

以下是正确代码:

  1. 负数:从小到大依次反转负数
  2. 非负数:只操作最小值,并且只在剩余k为奇数时反转最小值
  3. 两次排序
class Solution: def largestSumAfterKNegations(self, nums: List[int], k: int) -> int: nums.sort() # 翻转所有负数 for i in range(len(nums)): if nums[i] < 0 and k > 0: nums[i] = -nums[i] k -= 1 # 如果k还有剩余 if k % 2 == 1: # 翻转当前最小的元素 nums.sort() # 重新排序找到最小值 nums[0] = -nums[0] return sum(nums)
http://www.cnnetsun.cn/news/96007.html

相关文章:

  • 月薪3千到1万5,一名零售业上班族的逆袭:靠一本证书在“AI+”浪潮中突围
  • 只需5个步骤带你了解渗透测试全过程,SSH端口22如何完全沦陷!
  • 一个漏洞2w+,网安副业挖SRC漏洞,躺着把钱挣了!挖漏洞平均一天收入多少?
  • 数据血缘追踪与质量监控实现方法
  • 【编程干货】大模型开发文档处理秘籍,让你的RAG系统性能提升10倍!
  • 【AI开发必备】Mini Agent:零门槛构建智能Agent,支持MCP工具和无限长任务,GitHub已爆![特殊字符]
  • 栈与队列学习笔记
  • Oracle回滚与撤销技术
  • 我的mybatis-flex自定义查询为什么没有参数
  • 揭秘Dify混合检索缓存机制:为何缓存清理如此重要?
  • 计划赶不上变化?错!是计划“根本赶不上开工”
  • 应用冷启动优化
  • java_base_(接口篇)省流版
  • 实测主流科技查新网站:它们如何解决专利与项目查新的双重需求?
  • 【收藏必备】零基础入门AI Agent:概念、结构、方法与开发框架全解析
  • vue基于Springboot框架实现新能源汽车4s店销售管理系统
  • 开关频率可调的永磁同步电机svpwm发电仿真模型,可调稳定发电电压,负载,母线电容可调,可用于...
  • C语言高阶玩法:函数指针与回调函数实战指南,让你的代码拥有“灵魂”
  • 基于SpringBoot的校园二手书交易平台的设计与实现
  • 数据结构与算法--007三数之和(medium)
  • C++ 模板初阶:泛型编程的入门指南
  • 基于Java实现优雅关闭的规范化方案设计与实现
  • 时序数据战场巅峰对决:金仓数据库 VS InfluxDB深度解析
  • Windows任务管理器中CPU相关指标怎么看?
  • 【必藏】大模型入行晚了?现在就是黄金时机!小白到入门的完整路线
  • 系统思考与认知习惯
  • 速藏!2026年免费免版权音乐素材网站推荐!正规版权保障,商用无压力不侵权
  • 【数据分享】1951-2024年我国省市县三级逐日、逐月和逐年近地面气温数据(Shp/Excel格式)
  • 金融行业广告投放:在合规的赛道上,实现精准增长
  • 长安汽车11月销量28.3万辆,同比增长2.3%