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

Day11,Hot100(贪心算法)

贪心

(1)121. 买卖股票的最佳时机

第 i 天卖出的最大利润,即在前面最低价的时候买入

class Solution:
    def maxProfit(self, prices: List[int]) -> int:
        min_price = prices[0]
        ans = 0

        for price in prices:
            ans = max(ans, price - min_price)
            min_price = min(min_price, price)
        
        return ans

(2)152. 乘积最大子数组 —— 美团一面

class Solution:
    def maxProduct(self, nums: List[int]) -> int:
        n = len(nums)
        f_max = [0] * n
        f_min = [0] * n
        f_max[0] = f_min[0] = nums[0]

        for i in range(1, n):
            x = nums[i]
            f_max[i] = max(f_max[i-1] * x, f_min[i-1] * x, x)
            f_min[i] = min(f_max[i-1] * x, f_min[i-1] * x, x)

        return max(f_max)

(3)55. 跳跃游戏

在这里插入图片描述

  • max_idx[i] 表示 nums[0 : max_idx] 所有元素中可以到达的最远位置
  • 所以只需逐个遍历每个位置, 判断从之前的位置开始跳能否到达该位置
class Solution:
    def canJump(self, nums: List[int]) -> bool:
        # max_idx[i] 表示 nums[0 : max_idx] 所有元素中可以到达的最远位置
        # 所以只需逐个遍历每个位置, 判断从之前的位置开始跳能否到达该位置
        max_idx = 0  

        for i,v in enumerate(nums):
            if i > max_idx:
                return False
            max_idx = max(max_idx, i + nums[i])

        return True        

(4)45. 跳跃游戏 II

在这里插入图片描述

只在无法继续走的时候才建桥,且建的是最远的桥,这是所有方案中最优的。

只遍历到 n-2 因为我们的边界 cur_right,在遍历到 n-2 后,更新后的 cur_right 一定是 > n-2的,所以一定大于等于 n-1
在这里插入图片描述

class Solution:
    def jump(self, nums: List[int]) -> int:
        # 只在无法继续走的时候才建桥,且建的是最远的桥,这是所有方案中最优的。
        ans = 0
        cur_right = 0  # 已构造桥的最远端
        next_right = 0  # 下一座桥的最远端

        for i in range(len(nums) - 1):
            next_right = max(next_right, i + nums[i])
            if cur_right == i:
                cur_right = next_right
                ans += 1
        
        return ans

(5)763. 划分字母区间

在这里插入图片描述
「同一字母最多出现在一个片段中」
意味着,一个片段若要包含字母 a,那么所有的字母 a 都必须在这个片段中

利用合并区间的思想,s = a b a b c b a c a d e f e g d e h i j h k l i j

  • a出现的区间为 [0,8]
  • b出现的区间为 [1,5]
  • c 出现的区间为 [4,7]

结合<45. 跳跃游戏 II>的思路,

  • 区间右端点相当于当前点能到达的最远位置,
  • 如果这个最远的位置都被前面最远区间的最远位置包含住了
  • 那么这两个区间需要合并为一个区间

end = i 时,说明从 strat 到 当前位置 i 中的所有元素的最远区间就是当前位置
所以把当前位置划分为一个区间

class Solution:
    def partitionLabels(self, s: str) -> List[int]:
        last = {v:i for i,v in enumerate(s)}  # 每个字母最后出现的位置
        
        start = end = 0
        ans = []

        for i,v in enumerate(s):
            end = max(end, last[v])
            if end == i:
                ans.append(end-start+1)
                start = i + 1
        
        return ans

相关文章:

  • 一文了解:部署 Deepseek 各版本的硬件要求
  • 突破加速度计的精度与量程瓶颈:HEROS-GAN技术
  • OpenWebUI配置异常的外部模型导致页面无法打开
  • 基于coze+微信小程序的ai对话
  • 【js逆向入门】图灵爬虫练习平台 第八题
  • .gitignore 文件中添加忽略 .pdb 文件
  • Flutter - StatefulWidget (有状态的 Widget) 和 生命周期
  • 算法——递归
  • Mysql表字段字符集未设置导致乱码问题
  • java excel xlsx 增加数据验证
  • JavaWeb登录认证
  • Linux实操——在服务器上直接从百度网盘下载(/上传)文件
  • 【MySQL】InnoDB中的Buffer Pool
  • CNN:卷积网络中设计1×1夹在主要卷积核如3×3前后的作用
  • 基于专利合作地址匹配的数据构建区域协同矩阵
  • 记录一次解决springboot需要重新启动项目才能在前端界面展示静态资源的问题--------使用热部署解决
  • java23种设计模式-责任链模式
  • Java全流程供应链系统开源方案:前端后端分离
  • 免实名服务器新选择:AWS海外服务器三大核心优势解析——以aliyun国际版为对比
  • 2025系统架构师(一考就过):案例之四:架构复用、架构评估、特定架构(DSSA)、架构开发方法(ABSD)
  • 手机做网站公司有哪些/58同城关键词怎么优化
  • 重庆企业网站建设/北京建站公司
  • 杭州网站建设公司联系方式/线下推广公司
  • 建站之星极速版/广告公司推广方案
  • 网页设计代码quot/seo专业技术培训
  • dede网站模版/如何把品牌推广出去