【状态机DP】力扣2786. 访问数组中的位置使分数最大

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

你 一开始 在数组的位置 0 处,你可以按照下述规则访问数组中的其他位置:

如果你当前在位置 i ,那么你可以移动到满足 i < j 的 任意 位置 j 。

对于你访问的位置 i ,你可以获得分数 numsi

如果你从位置 i 移动到位置 j 且 numsi 和 numsj 的 奇偶性 不同,那么你将失去分数 x 。

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

注意 ,你一开始的分数为 nums0

示例 1:

输入:nums = 2,3,6,1,9,2, x = 5

输出:13

解释:我们可以按顺序访问数组中的位置:0 -> 2 -> 3 -> 4 。

对应位置的值为 2 ,6 ,1 和 9 。因为 6 和 1 的奇偶性不同,所以下标从 2 -> 3 让你失去 x = 5 分。

总得分为:2 + 6 + 1 + 9 - 5 = 13 。

示例 2:

输入:nums = 2,4,6,8, x = 3

输出:20

解释:数组中的所有元素奇偶性都一样,所以我们可以将每个元素都访问一次,而且不会失去任何分数。

总得分为:2 + 4 + 6 + 8 = 20 。

动态规划

css 复制代码
class Solution {
public:
    long long maxScore(vector<int>& nums, int x) {
        long long res = nums[0];
        int n = nums.size();
        vector<long long> dp(2, INT_MIN);
        dp[nums[0]%2] = nums[0];
        for(int i = 1; i < n; i++){
            int k = nums[i] % 2;
            long long cur = max(dp[k] + nums[i], dp[1-k] + nums[i] - x);
            res = max(res, cur);
            dp[k] = cur;
        }
        return res;
    }
};

时间复杂度:O(n),其中 n 是数组 nums 的长度。

空间复杂度:O(1)。

对于这道题目,我们可以定义一个容量为2的dp数组来说明他的奇偶性,并储存最后移动的元素为偶数时得分的最大值和最后移动的元素为奇数时得分的最大值。

在访问位置i的时候,假设i是奇数,则最大的dp1有可能是从上一个最大dp1加上当前numsi转移而来,或者是从上一个最大dp0加上numsi减去x转移而来,由于numsi在题目中大于0,则cur无论如何都会比之前的dp1要大。

然后我们通过res来记录最大的得分情况,并在循环最后,更新dp1为cur。以上是以奇数举例,偶数同理。

相关推荐
2zcode14 分钟前
项目文档:基于MATLAB语音信号变声算法设计与实现
算法·matlab·语音识别
指令集梦境19 分钟前
图解:单调栈算法模板(Java语言)
java·开发语言·算法
生成论实验室41 分钟前
自动驾驶:一个自主运动的系统
人工智能·算法·机器学习·语言模型·机器人·自动驾驶·安全架构
sheeta199843 分钟前
LeetCode 每日一题笔记 日期:2026.06.16 题目:3612. 字符串特殊符号处理
笔记·算法·leetcode
CoderYanger1 小时前
A.每日一题:2095. 删除链表的中间节点
java·数据结构·程序人生·leetcode·链表·面试·职场和发展
青山木1 小时前
Hot 100 --- 矩阵置零
线性代数·算法·leetcode·矩阵·哈希算法
Jasmine_llq1 小时前
《B4264 [GESP202503 四级] 二阶矩阵》
线性代数·算法·矩阵·二维矩阵遍历枚举所有2×2矩阵·交叉乘积等式条件判断·输入输出快读加速·长整型防溢出计数统计
周末也要写八哥1 小时前
面经经验分享|熟练掌握面试考点
经验分享·面试·职场和发展
不知名的老吴1 小时前
面经经验分享|算法和数据结构考察
数据结构·经验分享·算法
叫我:松哥1 小时前
基于Python flask的中学可控智能命题系统设计与实现,整合遗传算法、DeepSeek 大模型及数据库技术构建一体化应用
数据库·人工智能·python·算法·机器学习·flask·遗传算法