力扣每日一题(2024-06-14)2786. 访问数组中的位置使分数最大

2024-06-14 11:12

本文主要是介绍力扣每日一题(2024-06-14)2786. 访问数组中的位置使分数最大,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考官方题解2786. 访问数组中的位置使分数最大 - 力扣(LeetCode)

问题描述

给定一个下标从 0 开始的整数数组 nums 和一个正整数 x。你一开始在数组的第 0 个位置,你可以移动到满足 i < j 的任意位置 j。如果你访问的位置 i,你可以获得分数 nums[i]。如果从位置 i 移动到位置 jnums[i]nums[j] 的奇偶性不同,那么你将失去分数 x。请返回你能得到的最大得分之和。

动态规划思想

我们需要用动态规划来解决这个问题,通过维护一个状态数组来记录在不同奇偶性下的最大得分。具体地:

  1. 状态定义

    • dp[0] 表示当前最后一个元素为偶数时的最大得分。

    • dp[1] 表示当前最后一个元素为奇数时的最大得分。

  2. 状态初始化

    • 初始情况下,你在位置 0,所以得分为 nums[0]

    • 根据 nums[0] 的奇偶性,初始化对应的 dp 值。

  3. 状态转移: 对于数组中的每一个元素 nums[i],计算当前元素为奇数或偶数的情况下的最大得分。

    • 如果 nums[i] 是偶数,parity = 0

    • 如果 nums[i] 是奇数,parity = 1

    • cur 表示当前最大得分,可以通过两种方式计算得到:

      1. 当前元素与上一个同奇偶性,则得分为 dp[parity] + nums[i]

      2. 当前元素与上一个不同奇偶性,则得分为 dp[1 - parity] + nums[i] - x

    • 更新 dp[parity] 为当前奇偶性情况下的最大得分。

    • 更新 res 为当前最大得分。

  4. 返回结果: 返回最终最大得分 res

代码详解

class Solution {public long maxScore(int[] nums, int x) {// 初始化long res = nums[0];  // 初始化结果为第一个元素的值long[] dp = {Integer.MIN_VALUE, Integer.MIN_VALUE}; dp[nums[0] % 2] = nums[0];  // 初始化 dp,依据第一个元素的奇偶性for (int i = 1; i < nums.length; i++) {// 计算当前元素的奇偶性int parity = nums[i] % 2;  // 计算当前最大得分long cur = Math.max(dp[parity] + nums[i], dp[1 - parity] + nums[i] - x);  // 更新 res = Math.max(res, cur);  dp[parity] = Math.max(dp[parity], cur); }return res;}
}

这篇关于力扣每日一题(2024-06-14)2786. 访问数组中的位置使分数最大的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1060244

相关文章

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

Javascript访问Promise对象返回值的操作方法

《Javascript访问Promise对象返回值的操作方法》这篇文章介绍了如何在JavaScript中使用Promise对象来处理异步操作,通过使用fetch()方法和Promise对象,我们可以从... 目录在Javascript中,什么是Promise1- then() 链式操作2- 在之后的代码中使

Java中数组转换为列表的两种实现方式(超简单)

《Java中数组转换为列表的两种实现方式(超简单)》本文介绍了在Java中将数组转换为列表的两种常见方法使用Arrays.asList和Java8的StreamAPI,Arrays.asList方法简... 目录1. 使用Java Collections框架(Arrays.asList)1.1 示例代码1.

如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N... 目录docker部署FTP和Nginx并通过HTTP访问FTP里的文件1. 部署 FTP 服务器 (

C++一个数组赋值给另一个数组方式

《C++一个数组赋值给另一个数组方式》文章介绍了三种在C++中将一个数组赋值给另一个数组的方法:使用循环逐个元素赋值、使用标准库函数std::copy或std::memcpy以及使用标准库容器,每种方... 目录C++一个数组赋值给另一个数组循环遍历赋值使用标准库中的函数 std::copy 或 std::

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

本地搭建DeepSeek-R1、WebUI的完整过程及访问

《本地搭建DeepSeek-R1、WebUI的完整过程及访问》:本文主要介绍本地搭建DeepSeek-R1、WebUI的完整过程及访问的相关资料,DeepSeek-R1是一个开源的人工智能平台,主... 目录背景       搭建准备基础概念搭建过程访问对话测试总结背景       最近几年,人工智能技术

Ollama整合open-webui的步骤及访问

《Ollama整合open-webui的步骤及访问》:本文主要介绍如何通过源码方式安装OpenWebUI,并详细说明了安装步骤、环境要求以及第一次使用时的账号注册和模型选择过程,需要的朋友可以参考... 目录安装环境要求步骤访问选择PjrIUE模型开始对话总结 安装官方安装地址:https://docs.