Leetcode3040. 相同分数的最大操作数目 II

2024-06-10 07:28

本文主要是介绍Leetcode3040. 相同分数的最大操作数目 II,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Every day a Leetcode

题目来源:3040. 相同分数的最大操作数目 II

解法1:记忆化搜索

第一步可以做什么?做完后,剩下要解决的问题是什么?

  • 删除前两个数,剩下 nums[2] 到 nums[n−1],这是一个连续的子数组。
  • 删除后两个数,剩下 nums[0] 到 nums[n−3],这也是一个连续的子数组。
  • 删除第一个和最后一个数,剩下 nums[1] 到 nums[n−2],这还是一个连续的子数组。

无论怎么删除,剩下的都是连续子数组,都是和原问题相似的,规模更小的子问题。我们可以用子数组的左右端点下标表示状态,状态的值就是这个子数组的操作次数。

如果确定了第一次删除的元素和,那么后续删除的元素和也就确定了(因为每次操作的元素和必须相等)。三种操作,对应着至多三种不同的元素和,分别用三次区间 DP 解决。

代码:

#
# @lc app=leetcode.cn id=3040 lang=python3
#
# [3040] 相同分数的最大操作数目 II
## @lc code=start
class Solution:def maxOperations(self, nums: List[int]) -> int:@cachedef dfs(i: int, j: int, target: int) -> int:if i >= j:return 0res = 0# 删除前两个数if nums[i] + nums[i + 1] == target:res = max(res, dfs(i + 2, j, target) + 1)# 删除后两个数if nums[j - 1] + nums[j] == target: res = max(res, dfs(i, j - 2, target) + 1)# 删除第一个和最后一个数if nums[i] + nums[j] == target:res = max(res, dfs(i + 1, j - 1, target) + 1)return resn = len(nums)res1 = dfs(2, n - 1, nums[0] + nums[1])  # 删除前两个数res2 = dfs(0, n - 3, nums[-2] + nums[-1])  # 删除后两个数res3 = dfs(1, n - 2, nums[0] + nums[-1])  # 删除第一个和最后一个数return max(res1, res2, res3) + 1  # 加上第一次操作# @lc code=end

结果:

在这里插入图片描述

复杂度分析:

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

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

解法2:动态规划

代码:

/** @lc app=leetcode.cn id=3040 lang=cpp** [3040] 相同分数的最大操作数目 II*/// @lc code=start// 区间 DP + 记忆化搜索class Solution
{
public:int maxOperations(vector<int> &nums){if (nums.size() < 2)return 0;int n = nums.size();int memo[n][n];function<int(int, int, int)> helper = [&](int i, int j, int target) -> int{memset(memo, -1, sizeof(memo));function<int(int, int)> dfs = [&](int i, int j) -> int{if (i >= j)return 0;int &res = memo[i][j]; // 注意这里是引用if (res != -1)return res;res = 0;// 删除前两个数if (nums[i] + nums[i + 1] == target)res = max(res, dfs(i + 2, j) + 1);// 删除后两个数if (nums[j - 1] + nums[j] == target)res = max(res, dfs(i, j - 2) + 1);// 删除第一个和最后一个数if (nums[i] + nums[j] == target)res = max(res, dfs(i + 1, j - 1) + 1);return res;};return dfs(i, j);};// 删除前两个数int res1 = helper(2, n - 1, nums[0] + nums[1]);// 删除后两个数int res2 = helper(0, n - 3, nums[n - 2] + nums[n - 1]);// 删除第一个和最后一个数int res3 = helper(1, n - 2, nums[0] + nums[n - 1]);int ans = max({res1, res2, res3}) + 1; // 加上第一次操作return ans;}
};
// @lc code=end

结果:

在这里插入图片描述

复杂度分析:

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

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

这篇关于Leetcode3040. 相同分数的最大操作数目 II的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要