将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;         }
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1523921.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

redis缓存的目的、场景、实现、一致性问题

文章目录 1、加缓存的目的&#xff08;作用&#xff09;&#xff1a;2、加缓存的场景&#xff1a;读多写少3、加不加缓存的标准&#xff1a;4、缓存的实现&#xff1a;5、缓存的实现方案&#xff1a;6、缓存的粒度问题7、缓存的一致性问题 专辑详情和声音详情属于并发量较高的数…

SAP SUIM查到用户有事务码T-CODE权限,但是通过T-CODE查不到角色

类似于这种权限分配的方式&#xff0c;用事务码是查不到这个角色&#xff0c;但是通过SUIM查事务码的用户权限是可以查到的。 还有一种&#xff0c;是事务码给了*值.也会导致SUIM通过事务码查询角色&#xff0c;再通过角色查看用户&#xff0c;和通过用户查看有权限的事务码不一…

阿里巴巴发布 Qwen2-VL 人工智能模型,具备先进的视频分析和推理能力

中国阿里巴巴集团的云计算部门阿里云周四宣布推出一款名为 Qwen2-VL 的新型人工智能模型&#xff0c;该模型具有高级视觉理解能力和多语言对话能力。 该公司在 Qwen-VL 人工智能模型的基础上&#xff0c;历时一年研发出了新模型&#xff0c;并表示它可以实现对长度超过 20 分钟…

【书生3.5】茴香豆:企业级知识库问答工具

茴香豆&#xff1a;企业级知识库问答工具 1 简介2 web版使用3 本地版搭建3.1 环境安装3.2 模型准备下载源码安装依赖 3.3 修改配置3.4 知识库创建3.5 测试知识助手3.5.1 命令行运行3.5.2 可视化界面 3.6 集成飞书&微信群聊 4 高阶应用4.1 开启网络搜索4.2 远程模型远程向量…

10.8 信息安全基础知识

信息安全 存储安全 计算机信息系统安全保护等级 真题

Get full article in Google Sheet using Openai

题意&#xff1a;将整篇文章导入Google表格中&#xff0c;使用OpenAI。 问题背景&#xff1a; Im trying to get full article in Google Sheet using Openai API. In column A I just mention the topic and want to get full article in column B. 我正在尝试使用 OpenAI A…

chapter13-常用类——(包装类)——day15

目录 460-八大Wrapper类 461-装箱和拆箱 462-包装类测试 463-包装类方法 464-Integer创建机制 465-Integer面试题 460-八大Wrapper类 &#xff08;面向对象里面最重要的就是继承关系&#xff0c;所以要进行梳理&#xff09; 实现了了两个接口&#xff0c;继承了Object父…

2025年最新:如何用Java SpringBoot构建受灾救援物资管理系统,提升救援效率,掌握实时数据!

✍✍计算机编程指导师 ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡ Java实战 |…

错误: 找不到或无法加载主类 App.class,Java文件是怎么编译的

App.java文件: 文件路径:D:\com\fdw\App.java 文件内容: package com.fdw; public class App {public static void main(String[] args) {System.out.println("apple");} } 注意: App.java 必须放在com\fdw目录下(包名要和目录一致),否则无法启动! 编译

CNN-LSTM用于时间序列预测,发二区5分+没问题!

为了进一步提高时序预测的性能&#xff0c;研究者们组合了CNN和LSTM的特点&#xff0c;提出了CNN-LSTM混合架构。 这种架构因为独特的结构设计&#xff0c;能同时处理时空数据、提取丰富的特征、并有效解决过拟合问题&#xff0c;实现对时间序列数据的高效、准确预测&#xff…

我的私有云-IOT定位/追踪系统

目录 1. 说明 2. 完成后的效果 2.1 实时定位 2.2 轨迹重现 2.3 设备美照 3. 项目设计 3.1 系统拓扑图​编辑 3.2 技术选型 3.3 消息订阅处理架构图 3.4 frp服务在线监控​编辑 4. 实施 4.1 数据模型 - DeviceLocation 4.2 数据报规格定义 订阅主题 数据报格式 …

【Qt】Qt 网络 | UDP Socket

文章目录 核心API代码示例服务器客户端 要使用 Qt 网络编程&#xff0c;需要在项目中的 .pro 文件中添加 network 模块 核心API Qt 的 UDP Socket 主要的类有两个 QUdpSocket 和 QNetworkDatagram 因为是 UDP 是面向数据报的&#xff0c;QNetworkDatagram 就是对 数据报的封…

ChatGPT写文章时,如何去除生硬的Ai味?

仅做分享&#xff0c;侵删 在使用AI进行写作时&#xff0c;常常会发现生成的文章带有明显的“机器味”&#xff0c;一眼就能看出是由AI生成的。这是许多希望借助AI进行自媒体创作的小伙伴们面临的一个主要问题。AI生成的文章往往过于书面化&#xff0c;缺乏人情味&#xff0c;导…

Xmind2024去除VIP会员解锁版

XMind 2024&#xff1a;让思维导图变得有趣又高效 &#x1f31f;新功能大揭秘&#x1f31f; 亲爱的小仙女们&#xff0c;今天我要给你们安利一款神奇的软件——XMind 2024&#xff01;这不仅仅是一款普通的思维导图软件&#xff0c;它可是集美貌与智慧于一身的超级助手哦&…

【学习笔记】 陈强-机器学习-Python-Ch13 提升法

系列文章目录 监督学习&#xff1a;参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归&#xff08;SAheart.csv&#xff09; 【学习笔记】 陈强-机器学习-Python-…

3674B/C/D/E/F/G矢量网络分析仪

3674B/C/D/E/F/G矢量网络分析仪 <<<3674系列矢量网络分析仪>>> Ceyear 3674系列矢量网络分析仪是技术创新的巅峰之作&#xff0c;可以轻松应对半导体芯片测试、材料测试、天线测试、高速线缆测试、微波部组件测试等带来的严峻挑战。出色的射频特性、灵活的硬…

提升多跳问答中的语言模型知识编辑能力

人工智能咨询培训老师叶梓 转载标明出处 大模型在静态知识库的更新上存在局限&#xff0c;特别是在面对需要多步骤推理的多跳问题时&#xff0c;难以提供准确和最新的回答。为了解决这一问题&#xff0c;来自美国佐治亚大学、纽约大学、莱斯大学、北卡罗来纳州立大学等机构的研…

案例-KVM+GFS分布式存储系统构建KVM高可用(虚拟化实战)

NFS GlusterFS 基于共享存储 采用GFS做共享存储&#xff1b; 实验环境&#xff1a;101 102 103 104 做gfs集群&#xff1b;201 202做虚拟机&#xff1b; 同步一下会话&#xff1b; 为了方便使用主机名进行通信&#xff0c;修改hosts文件&#xff1b; 为了使用GlusterFS的仓库…

机器学习引领未来:赋能精准高效的图像识别技术革新

图像识别技术近年来取得了显著进展,深刻地改变了各行各业。机器学习,特别是深度学习的突破,推动了这一领域的技术革新。本文将深入探讨机器学习如何赋能图像识别技术,从基础理论到前沿进展,再到实际应用与挑战展望,为您全面呈现这一领域的最新动态和未来趋势。 1. 引言 …

Python进阶07-高级语法

零、文章目录 Python进阶07-高级语法 1、with语句 &#xff08;1&#xff09;文件操作 文件使用完后必须关闭&#xff0c;因为文件对象会占用操作系统的资源&#xff0c;并且操作系统同一时间能打开的文件数量也是有限的 # 第一步&#xff1a;打开文件 f open(python.txt…