将x减到零的最小操作数问题

2024-09-05 01:36
文章标签 问题 最小 操作数 减到

本文主要是介绍将x减到零的最小操作数问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 欢迎跳转我的主页:羑悻的小杀马特-CSDN博客

目录

一·题目简述:

二·题目思路:

三·解答代码:


一·题目简述:

leetcode题目链接:. - 力扣(LeetCode) 

二·题目思路:

首先这道题,可能如果直接正面从最左最右开始找数值之和为x,这样看起来比较散,而我们不难发现中间肯定会有一段连续的区域,因此leetcode这道题肯定想让我们用这种逆向的思维方式来解决。

因此这道题不就转换成了让我们找中间的区域等于sum-x的最长区间。

因此回归正轨,也就是下面要用滑动窗口来维护,而窗口内的数据就是这段区域的和,然后可以控制这段窗口保持总值为sum-x,那么我们就开始更新数据,并统计最大值,下面来用画图的方式演示一下(我们例子就不一一列举了,举几个有代表性的即可):

我们用视频动态展示一下操作:

演示效果

接着可能会有一个疑问:

 

 

下面可能会有两个特殊情况,这就简单说一下,也就是它要返回-1的情况:

比如是[1,2] x=8,则target就是负数,这样直接返回-1;

另一种就是类似[2,3] x=1 ,这时虽然target>0但是当缩小窗口的时候会发现,它不会等于target即要保存的ret不会更新,故到最后直接返回ret即可。

也许会看到题目有个限制就是:

这里为什么要是正数,这里我们举个例子:

加入:[-1,-7,5,1] x=1, target=-3; 但是这样会出现和都为正数时候target<0,也就会直接返回-1,因此会出现矛盾,题目规定不能是负数。 

 

最后规整一下思路: 

思路:滑动窗口+逆向思维:(转成找中间连续区域的值等于sum-x的最长区间元素个数)即要保证tmp不能大于target,一开始直接进窗口,tmp>target就开始出

窗口,即left朝右活动,开始对tmp开始减小,此时出了while可能会发现小于或者等于,而需要的是等于,故等于的时候开始用max统计,最后for后完成相应的输出操作

注意:两极端:target小于0,直接返回-1,否则后面进数组,会发生栈溢出行为,另一种是target虽然大于0,但是后面无论如何也不会到更新ret环节,故后面直接

返回-1;

三·解答代码:

class Solution {
public:int minOperations(vector<int>& nums, int x) {int sum=0,n=nums.size();for(auto a :nums){sum+=a;}//极端1:[1,2] x=8;此时target<0;int target=sum-x;if(target<0) return -1;//中间最长区间的值应该等于targetint ret=-1;for( int left,right=0 ,tmp=0;right<n;right++){tmp+=nums[right];//一开始直接入窗口while(tmp>target)//窗口过大就左端出窗口tmp-= nums[left++];if(tmp==target){ret=max(ret,right-left+1);//符合就出窗口后更新}// 极端2:[2,3] x=1;target>0;但是出窗口后得不到tmp==target;}if(ret==-1)  return ret;else return n-ret;         }
};

这篇关于将x减到零的最小操作数问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQ中出现幻读问题的解决过程

《MySQ中出现幻读问题的解决过程》文章解析MySQLInnoDB通过MVCC与间隙锁机制在可重复读隔离级别下解决幻读,确保事务一致性,同时指出性能影响及乐观锁等替代方案,帮助开发者优化数据库应用... 目录一、幻读的准确定义与核心特征幻读 vs 不可重复读二、mysql隔离级别深度解析各隔离级别的实现差异

C++ vector越界问题的完整解决方案

《C++vector越界问题的完整解决方案》在C++开发中,std::vector作为最常用的动态数组容器,其便捷性与性能优势使其成为处理可变长度数据的首选,然而,数组越界访问始终是威胁程序稳定性的... 目录引言一、vector越界的底层原理与危害1.1 越界访问的本质原因1.2 越界访问的实际危害二、基

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.