LeetCode每日一题 | 1696. 跳跃游戏 VI

文章目录

题目描述

给你一个下标从 0 开始的整数数组 nums 和一个整数 k 。

一开始你在下标 0 处。每一步,你最多可以往前跳 k 步,但你不能跳出数组的边界。也就是说,你可以从下标 i 跳到 [i + 1, min(n - 1, i + k)] 包含 两个端点的任意位置。

你的目标是到达数组最后一个位置(下标为 n - 1 ),你的 得分 为经过的所有数字之和。

请你返回你能得到的 最大得分 。

问题分析

状态表示:dp[i]表示到达位置 i 的最大得分

初始状态:dp[0] = nums[0]

状态计算:dp[i] = max{dp[j]},其中max(0,i−k) <= j < i

其中前 k 步的最大值,可以用一个双端队列进行维护。

程序代码

go 复制代码
func maxResult(nums []int, k int) int {
    n := len(nums)
    dp := make([]int, n)
    dp[0] = nums[0]
    // 双端队列
    q := make([]int, n)
    qi, qj := 0, 1
    for i := 1; i < n; i++ {
        // 容量超了
        for qi < qj && q[qi] < i - k {
            qi++
        }
        dp[i] = dp[q[qi]] + nums[i]
        // 比你年轻,能力还比你强
        for qi < qj && dp[q[qj - 1]] <= dp[i] {
            qj--
        }
        q[qj] = i
        qj++
    }
    return dp[n-1]
}
相关推荐
穿越临界点9 小时前
动态规划(DP)
算法·动态规划·贝尔曼
leoufung10 小时前
LeetCode 50. Pow(x, n):从 O(n) 到 O(log n) 的快速幂彻底搞懂
算法·leetcode·职场和发展
开开心心就好10 小时前
无品牌限制的手机电视投屏工具推荐
科技·游戏·智能手机·edge·电脑·逻辑回归·powerpoint
@小码农10 小时前
2026年信息素养大赛【星火征途】图形化编程复赛和决赛模拟题B
开发语言·数据结构·c++·算法
人道领域10 小时前
【LeetCode刷题日记】347.前k个高频元素
java·数据结构·算法·leetcode
七颗糖很甜10 小时前
台风数据免费获取教程
大数据·python·算法
AI科技星10 小时前
《全域数学》第一部·数术本源
算法·机器学习·数学建模·数据挖掘·量子计算
阿Y加油吧10 小时前
二刷 LeetCode:118. 杨辉三角 & 198. 打家劫舍 复盘笔记
笔记·算法·leetcode
深邃-10 小时前
【数据结构与算法】-二叉树(1):树的概念与结构,二叉树的概念与结构
数据结构·算法·链表·二叉树··顺序表
风筝在晴天搁浅10 小时前
手撕归并排序
数据结构·算法·排序算法