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) 额外空间,适合大数据处理! 🚀

相关推荐
明月看潮生8 分钟前
青少年编程与数学 02-016 Python数据结构与算法 23课题、分布式算法
分布式·python·算法·青少年编程·编程与数学
冠位观测者15 分钟前
【Leetcode 每日一题】2176. 统计数组中相等且可以被整除的数对
数据结构·算法·leetcode
幼儿园园霸柒柒36 分钟前
第七章:7.2求方程a*x*x+b*x+c=0的根,用3个函数,分别求当:b*b-4*a*c大于0、等于0和小于0时的根并输出结果。从主函数输入a、b、c的值
c语言·开发语言·算法·c#
阳洞洞1 小时前
leetcode 213. House Robber II
算法·leetcode·动态规划
梭七y1 小时前
【力扣hot100题】(099)寻找重复数
算法·leetcode·职场和发展
小媛早点睡1 小时前
贪心算法day11(用最少数量的箭引爆气球)
算法·贪心算法
飞天狗1111 小时前
数据结构——二叉树
数据结构·算法
WW_千谷山4_sch1 小时前
MYOJ_11700(UVA10591)Happy Number(快乐数)(超快解法:图论思想解题)
c++·算法
Cosolar2 小时前
MCP技术应用全景:连接智能世界的万能接口
后端·算法
前端 贾公子2 小时前
力扣349 == 两个数组交集的两种解法
算法