模块二——滑动窗口:1658.将x减到0的最小操作数

2023-12-07 14:20

本文主要是介绍模块二——滑动窗口:1658.将x减到0的最小操作数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

模块二

  • 一、题目解析
  • 二、算法原理
  • 三、代码编写
    • 解法一:暴力枚举(超时)
    • 解法二:滑动窗口(时间复杂度是O(n),空间复杂度是O(1))

一、题目解析

题目链接:1658.将x减到0的最小操作数
在这里插入图片描述
这道题的意思是让我们求出x - (每次取数组最左边或者最右边的值) -> 0的最小操作次数并返回,否则返回-1。(PS:最左边和最右边的操作可以为0)

二、算法原理

题⽬要求的是数组「左端+右端」两段连续的、和为 x 的最短数组,信息量稍微多⼀些,不易理清思路;我们可以转化成求数组内⼀段连续的、和为sum(nums) - x 的最⻓数组。此时,就是熟悉的「滑动窗⼝」问题了。
在这里插入图片描述
初始化左右指针left = 0 ,right = 0 (滑动窗⼝区间表⽰为[left,right) ,左右区间是否开闭很重要,必须设定与代码⼀致),当target<0时问题无解(数组总和小于x则再怎么减都无法减到0)。

三、代码编写

解法一:暴力枚举(超时)

class Solution {
public:int minOperations(vector<int>& nums, int x) {//暴力枚举int n = nums.size(),numsSum = 0,minOp = 0;for(int i = 0;i < n;i++){numsSum += nums[i];//求数组的总和}int target = numsSum - x;//target记录numsSum-xif(target < 0)return -1;else if(target == 0)return n;for(int left = 0;left < n;left++){int sum = 0;//记录left到right的总和for(int right = left;right < n;right++){sum += nums[right];if(target == sum)minOp = max(minOp,right - left + 1);}}if(minOp == 0)return -1;else return n - minOp;}
};

解法二:滑动窗口(时间复杂度是O(n),空间复杂度是O(1))

class Solution {
public:int minOperations(vector<int>& nums, int x) {//滑动窗口int n = nums.size(),minOp = -1,sum = 0;int numsSum = accumulate(nums.begin(), nums.end(), 0);//记录数组总和int target = numsSum - x;//转化问题if(target < 0)return -1;for(int left = 0,right = 0;right < n;right++){sum += nums[right];//进窗口while(sum > target)//判断sum -= nums[left++];if(target == sum)minOp = max(minOp,right - left + 1);//更新结果}if(minOp == -1)return -1;else return n - minOp;}
};

这篇关于模块二——滑动窗口:1658.将x减到0的最小操作数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx添加内置模块过程

《Nginx添加内置模块过程》文章指导如何检查并添加Nginx的with-http_gzip_static模块:确认该模块未默认安装后,需下载同版本源码重新编译,备份替换原有二进制文件,最后重启服务验... 目录1、查看Nginx已编辑的模块2、Nginx官网查看内置模块3、停止Nginx服务4、Nginx

python urllib模块使用操作方法

《pythonurllib模块使用操作方法》Python提供了多个库用于处理URL,常用的有urllib、requests和urlparse(Python3中为urllib.parse),下面是这些... 目录URL 处理库urllib 模块requests 库urlparse 和 urljoin编码和解码

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提