news 2026/5/9 11:17:15

day24-数据结构力扣

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
day24-数据结构力扣

122.买卖股票的最佳时机II

题目链接122. 买卖股票的最佳时机 II - 力扣(LeetCode)

思路

这个题感觉和之前一个题有点像,就是摆动序列,但是又有点不太一样

本题的核心规则:

  • 可以无限次买卖

  • 任何时候最多持有 1 股

  • 同一天可以买了再卖

  • 最大利润

只要后一天价格 > 前一天价格,就把这两天的差价赚到手。所有上涨日的差价加起来 = 最大利润。

为什么正确?连续上涨(1→2→3→4→5),每天赚差价:(2-1)+(3-2)+(4-3)+(5-4) = 5-1,和一次买卖结果完全一样

两个题的区别:

  • 股票题只赚涨的钱,跌的不碰

  • 摆动序列交替涨跌都算,统计最长长度

提交

很神奇,我以为会是很复杂的手段,结果和我想的不一样,有一种四两拨千斤的感觉

仿佛大脑的褶皱被抚平

class Solution: def maxProfit(self, prices: List[int]) -> int: profit = 0 # 从第2天开始遍历 for i in range(1, len(prices)): # 只要今天比昨天贵,就赚差价 if prices[i] > prices[i-1]: profit += prices[i] - prices[i-1] return profit

55. 跳跃游戏

题目链接55. 跳跃游戏 - 力扣(LeetCode)

思路

首先,我没看懂题的意思?又开始阅读理解了

规则

  • 数组nums[i]:在位置i最多能跳几步

  • 起点:下标0

  • 目标:判断能不能到达最后一个下标

示例 1: 输入:nums = [2,3,1,1,4]

输出:true 解释:可以先跳 1 步,从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。

我懂了,每个数组位置数字,是最多能跳几步

核心思想

  1. 用一个变量max_reach记录当前能跳到的最远位置

  2. 遍历数组,每到一个位置,就更新最远能跳到哪

  3. 如果遍历的位置超过了最远可达位置,说明卡住了,直接返回false

  4. 如果最远位置 >= 最后一个下标,直接返回true

一句话:只要当前位置还能跳到,就不断更新最远跳跃距离

提交

class Solution: def canJump(self, nums: List[int]) -> bool: max_reach = 0 # 记录当前能跳到的最远下标 n = len(nums) for i in range(n): # 如果当前位置都跳不到,直接失败 if i > max_reach: return False # 更新最远能跳到的位置 max_reach = max(max_reach, i + nums[i]) # 已经能跳到终点,提前返回 if max_reach >= n - 1: return True return True

45.跳跃游戏II

题目链接45. 跳跃游戏 II - 力扣(LeetCode)

思路

这简直就是55跳跃游戏的plus版本

  • 核心逻辑:不关心每一步具体跳到哪个位置,只关心当前能到达的最远位置,当遍历到当前跳跃的边界时,必须进行一次跳跃,同时更新边界为新的最远位置。

  • 三个关键变量

    • jumps:记录最小跳跃次数(最终结果)

    • current_end:当前这一步能到达的最远边界

    • farthest:遍历过程中能到达的全局最远位置

  • 遍历规则

    • 遍历数组(不需要遍历最后一个元素,因为到了最后一个元素就已经到达终点)

    • 每遍历一个位置,更新能到达的最远位置farthest

    • 当遍历到current_end时,说明必须跳一步,jumps+1,并把current_end更新为farthest

nums = [2,3,1,1,4]为例:

  1. 初始:jumps=0, current_end=0, farthest=0
  2. i=0
    • farthest = max(0, 0+2) = 2
    • i == current_endjumps=1current_end=2
  3. i=1
    • farthest = max(2, 1+3) = 4
  4. i=2
    • farthest = max(4, 2+1) = 4
    • i == current_endjumps=2current_end=4(已经到达终点,退出)
  5. 最终返回2

提交

class Solution: def jump(self, nums: List[int]) -> int: n = len(nums) jumps = 0 # 记录跳跃次数 current_end = 0 # 当前跳跃的边界 farthest = 0 # 能到达的最远位置 # 不需要遍历最后一个元素,因为已经到达终点 for i in range(n - 1): # 更新最远能到达的位置 farthest = max(farthest, i + nums[i]) # 到达当前边界,必须跳一次 if i == current_end: jumps += 1 current_end = farthest # 优化:如果已经能跳到终点,直接提前退出 if current_end >= n - 1: break return jumps

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

题目链接1005. K 次取反后最大化的数组和 - 力扣(LeetCode)

思路

依旧还是先做阅读理解

k是指可以选择k个数字将他们的正负号反转,但是具体反转那个不知道。

有不同的反转方案

我们要得到最佳方案,就是这些方法里面数组之和最大的那个结果

第一版思路:通过66/84

可以先把数组排序,我们反转数组里面较小的数字

对于正数:反转之后减的最少,那就是反最小的正数

对于负数:反转之后加的最大,反负更多的,也就是更小的负数

比如【4,2,3】k=1,排序【2,3,4】就是反转2

【2,-3,-1,5,-4】k=2,排序【-4,-3,-1,2,5】反转-4,-3

但是有一种特殊情况 就是有0的:

因为题目说有些下标是可以多次反转的

那我们把负的反过来之后,还有次数就反转0

这里正数部分应该单独处理

比如把正数反转之后,我们应该找修改数组后的最小值反转

而不是继续遍历反转

提交

from typing import List class Solution: def largestSumAfterKNegations(self, nums: List[int], k: int) -> int: # 从小到大排序,优先翻转最小的负数(收益最大) nums.sort() for i in range(len(nums)): if nums[i]<0: # 翻转当前最小负数为正数,消耗一次翻转次数 nums[i] = -nums[i] k -= 1 if k == 0: # 翻转次数用完,直接退出 break elif nums[i]==0: # 遇到0,剩余次数全部翻转0,总和不变 k = 0 break else: # 后面全是正数,无需继续翻转 break if k>0 and k%2==1: # 剩余奇数次翻转,必须翻转一次最小值(损失最小) num=min(nums) index=nums.index(num) nums[index]=-nums[index] return sum(nums)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 10:38:50

实战体验:10分钟微调Qwen2.5-7B,实现AI身份自定义

实战体验&#xff1a;10分钟微调Qwen2.5-7B&#xff0c;实现AI身份自定义 想不想拥有一个能记住自己“出身”的专属AI助手&#xff1f;比如&#xff0c;让它坚定地认为自己是“由CSDN迪菲赫尔曼开发”的模型&#xff0c;而不是那个默认的“阿里云”身份&#xff1f; 听起来很…

作者头像 李华
网站建设 2026/4/15 10:28:38

手把手教你用STM32的PWM控制40st-m00330伺服电机,实现丝杠精准移动

STM32精准控制40ST-M00330伺服电机&#xff1a;从PWM配置到丝杠运动实战 在自动化设备和DIY项目中&#xff0c;精确控制机械运动是核心需求之一。40ST-M00330伺服电机配合丝杠结构&#xff0c;能够实现高精度的直线位移控制&#xff0c;广泛应用于3D打印机、CNC机床和小型自动…

作者头像 李华
网站建设 2026/4/15 10:28:14

2026年重庆瓶装水厂家发展趋势洞察与市场前景分析

一、开头&#xff1a;技术痛点/趋势引入2026年&#xff0c;随着市场需求的变化和消费者对健康饮水的关注度不断提高&#xff0c;瓶装水领域面临新的挑战。在技术社区里&#xff0c;经常有人讨论瓶装水厂家该如何进行技术升级和市场拓展。从架构演进、性能、成本、运维复杂度等维…

作者头像 李华