力扣每日一题(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++初始化数组的几种常见方法(简单易懂)

《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.

解读静态资源访问static-locations和static-path-pattern

《解读静态资源访问static-locations和static-path-pattern》本文主要介绍了SpringBoot中静态资源的配置和访问方式,包括静态资源的默认前缀、默认地址、目录结构、访... 目录静态资源访问static-locations和static-path-pattern静态资源配置

Java访问修饰符public、private、protected及默认访问权限详解

《Java访问修饰符public、private、protected及默认访问权限详解》:本文主要介绍Java访问修饰符public、private、protected及默认访问权限的相关资料,每... 目录前言1. public 访问修饰符特点:示例:适用场景:2. private 访问修饰符特点:示例:

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2