2023-05-12 LeetCode每日一题(翻转子数组得到的最大的数组值)

news/2024/11/24 12:10:43/

2023-05-12每日一题

一、题目编号

1330. 翻转子数组得到最大的数组值

二、题目链接

点击跳转到题目位置

三、题目描述

给你一个整数数组 nums 。「数组值」定义为所有满足 0 <= i < nums.length-1 的 |nums[i]-nums[i+1]| 的和。

你可以选择给定数组的任意子数组,并将该子数组翻转。但你只能执行这个操作 一次 。

请你找到可行的最大 数组值

四、解题代码

class Solution {
public:int maxValueAfterReverse(vector<int>& nums) {int n = nums.size();int res = 0;for(int i = 0; i < n-1; ++i){res += abs(nums[i] - nums[i+1]);}int res1 = 0;for(int i = 1; i < n - 1; ++i){res1 = max(res1, abs(nums[0] - nums[i+1]) - abs(nums[i] - nums[i+1]));}for(int i = n-2; i > 0; --i){res1 = max(res1, abs(nums[n-1] - nums[i-1]) - abs(nums[i] - nums[i-1]));}int num1 = INT_MIN;int num2 = INT_MAX;for(int i = 0; i < n-1; ++i){int x = nums[i];int y = nums[i+1];num1 = max(num1, min(x, y));num2 = min(num2, max(x, y));}return res + max(res1, 2 * (num1 - num2));}
};

五、解题思路

(1) 首先先计算整体的(即)不变的值,为res1,即一次枚举,按照题目要求计算即可。

(2) 接着我们思考一个问题,加入我们将位置i 到 位置j 的数字颠倒,实际上中间的子数组的数组值并没有发生改变,实际上变化的只是边缘的值,因而我们可以思考交换的位置所影响的边缘位置的数组值。

(3) 首先思考左端(下边为0)到右边一个下标i的子数组进行翻转,意味着实际变化的值为abs(nums[0] - nums[i+1]) - abs(nums[i] - nums[i+1]),记录一个最大值为res1。

(4) 接着思考右端(下标为n-1)到左边一个下标为i的子数组进行翻转,意味着实际变化的值为nums[n - 1] - nums[i - 1]) - abs(nums[i] - nums[i - 1]),记录为最大值为res1,实际上就是更新res1。

(5) 最后思考的是 下标为i 的数 到下标为 j 数之间的子数组翻转。此时改变的值为abs(nums[j] - nums[i-1]) + abs(nums[j+1] - nums[i]) - abs(nums[i] - nums[i-1]) - abs(nums[j+1] - nums[j-1])。分别记录nums[i-1] = a,nums[i] = b, nums[j] = c, nums[j+1] = d。 根据a、b、c、d四个值的大小可以得到不同的可能性。最后得出结论当两个相邻数对,当一个数对的较大值小于另一个数对的较小值时,求差值的两倍。

(6) 最后得出最大值即可。


http://www.ppmy.cn/news/68506.html

相关文章

银行太多怎么选?

无论在银行春招还是秋招中&#xff0c;不少同学都采用“海投”策略&#xff0c;以求有更多的笔试面试机会&#xff1b;还有同学有一颗想行动的心&#xff0c;但是却被“选择困难症”绊住脚步&#xff0c;不确定投哪个地区的银行、不确定哪家银行哪个岗位更适合自己、该选大城市…

postman处理各种请求数据

1、后台request接收postman参数 2、后台单个参数接收postman 3、后台RequestParam参数接收postman 注意事项&#xff1a;情况一&#xff1a;全部都是单个字符串的 情况二&#xff1a;有可能是一个json对象序列化成字符串过来的&#xff0c;那么需要在form-data中设置 …

Windows10安装二进制Mysql-5.7.41和汉化

1.创建my.ini [mysqld] ##skip-grant-tables1 port 3306 basedirD:/webStudy/mysql-5.7.41 datadirE:/adata/mysqlData max_connections200 character-set-serverutf8 default-storage-engineINNODB sql_modeNO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES [mysql] default-char…

Nginx之rewrite实现URL重写

1.开篇 rewrite是nginx服务器提供的一个重要功能&#xff0c;用于实现URL的重写。例如我们访问https://aa.qq.com&#xff0c;打开的是https://age.qq.com/&#xff0c;这就是使用URL重写的特性来实现的。 ngx_http_rewrite_module为实现URL重写提供了指令支持。 官方文档地…

边缘计算盒子有哪些?边缘计算应用场景

边缘计算&#xff08;Edge Computing&#xff09;是一种分布式计算模型&#xff0c;旨在将数据处理和计算功能从中心数据中心移到数据源附近的边缘设备上。它的目标是在接近数据生成的地方进行实时数据处理和分析&#xff0c;减少数据传输延迟和网络拥塞&#xff0c;提高应用程…

多态与虚函数

多态与虚函数 多态的引入多态与虚函数多态编译时多态运行时多态 多态的原理静态联编和动态联编 多态的引入 学过C继承的话应该都知道在继承中存在一种菱形继承&#xff0c;假设存在一个类&#xff08;person&#xff09;&#xff0c;其派生出两个子类&#xff0c;分别是studen…

ModuleNotFoundError: No module named ‘Multiscaledeformableattention‘

在实现DINO Detection方法时&#xff0c;我们可能会遇到以上问题。因为在DeformableAttention模块&#xff0c;为了加速&#xff0c;需要自己去编译这个模块。 如果你的环境变量中能够找到cuda路径&#xff0c;使用正确的torch版本和cuda版本的话&#xff0c;这个问题很容易解…

C++的string类使用介绍

string类 1.为什么要学习string类&#xff1f;1.1.C语言中的字符串1.2. 日常中 2. 标准库中的string类2.2 string类(对于单字节的字符)的常用接口说明①string常见的构造函数②string类对象的容量操作③string类对象的访问以及遍历操作④string类对象的修改操作⑤string类非成员…