python-leetcode-删除并获得点数

740. 删除并获得点数 - 力扣(LeetCode)

解法 1:动态规划(O(n) 时间,O(n) 空间)

python 复制代码
class Solution:
    def deleteAndEarn(self, nums: List[int]) -> int:
        if not nums:
            return 0

        # 统计每个数的贡献
        points = Counter(nums)
        max_val = max(nums)  # 找到数组中的最大值
        dp = [0] * (max_val + 1)

        # 构造 dp 数组
        for num in range(max_val + 1):
            dp[num] = num * points[num]

        # 打家劫舍
        prev, curr = 0, 0
        for num in range(max_val + 1):
            prev, curr = curr, max(curr, prev + dp[num])
        
        return curr

时间复杂度O(n)(遍历 nums 统计次数 + 遍历 dp 计算)

空间复杂度O(n)(使用 dp 数组)

解法 2:优化的动态规划(O(n) 时间,O(1) 空间)

  • 空间优化 :只存储 prevcurr,减少 dp 数组占用。
python 复制代码
class Solution:
    def deleteAndEarn(self, nums: List[int]) -> int:
        if not nums:
            return 0

        points = Counter(nums)
        max_val = max(nums)
        
        prev, curr = 0, 0  # 滚动变量代替 dp 数组
        for num in range(max_val + 1):
            prev, curr = curr, max(curr, prev + num * points[num])
        
        return curr

时间复杂度O(n)

空间复杂度O(1)(只用两个变量)

总结

方法 时间复杂度 空间复杂度 适用情况
DP 数组版 O(n) O(n) 适用于小规模输入
DP 滚动变量 O(n) O(1) 推荐,适合大规模输入

最佳选择 :用 滚动变量 版本,避免 O(n) 额外空间,适合大数据处理! 🚀

相关推荐
翻身的咸鱼ing13 小时前
常用代码知识
算法·深度优先·哈希算法
feifeigo12313 小时前
自适应大邻域搜索(ALNS)算法的MATLAB 实现
开发语言·算法·matlab
RH23121113 小时前
2026.4.29数据结构 直接插入排序&&希尔排序
数据结构·算法·排序算法
搬砖的小码农_Sky13 小时前
AI Agent:OpenClaw的算法架构
人工智能·算法·ai·架构·人机交互·agi
热心网友俣先生14 小时前
2026年金地杯A题解题思路
算法
科研前沿14 小时前
SpaceOS™空间计算底座与五大自研引擎,实现多项关键技术突破
大数据·运维·人工智能·算法·重构
昵称小白14 小时前
C++ 刷题语法速查
c++·算法
JQLvopkk14 小时前
C# 工业级数据可视化:用ScottPlot让10万个点流畅显示的实战秘籍
人工智能·算法·机器学习
神仙别闹14 小时前
基于C# 利用工程活动图 AOE 网设计算法
算法·c#·php
地平线开发者14 小时前
Linux 性能优化工具
算法·自动驾驶