当前位置: 首页 > news >正文

算法——双指针

1658. 将 x 减到 0 的最小操作数 - 力扣(LeetCode)

这道题的重点是,如何用最小的操作数,来使其x变为0——也可以看作是用最少的数据个数,来求和得到x。

——但是我们可以知道,由于数据是从两端向中间取的,所以每一次的数据取完后,中间的数据仍是连续的。

所以我们可以将题目从求和为x的最小数据个数——>求和为sum-x的最多数据个数

由于中间数据是连续的,所以我们可以用双指针来进行遍历查找

期间需要一个循环来进行修正

代码如下:

 int minOperations(vector<int>& nums, int x) {int n = nums.size();int sumarr = 0;for (auto e : nums){sumarr += e;}int left = 0, right = 0, sum = 0, res = sumarr - x, count = -1;if (res < 0)   return -1;while (right < n){sum += nums[right];while (sum > res)//进行修正{sum -= nums[left++];}if (sum == res){count = max(right - left+1 , count);//个数//保存个数,与下一次的匹配保存数据}right++;}if (count == -1) return -1;else return n - count;
}

http://www.lryc.cn/news/168781.html

相关文章:

  • 【PowerQuery】Excel的PowerQuery按需刷新
  • Django REST Farmowork初探
  • 【flink进阶】-- Flink kubernetes operator 版本升级
  • Linux Ubuntu20.04深度学习环境快速配置命令记录
  • 信息安全三级真题一
  • RK3568-tftp更新设备树和内核nfs挂载文件系统
  • FIR滤波器简述及FPGA仿真验证
  • 高速信号处理板资料保存:383-基于kintex UltraScale XCKU060的双路QSFP+光纤PCIe 卡设计原理图
  • QT:使用分组框、单选按钮、普通按钮、标签、行编辑器、垂直分布、水平分布做一个小项目
  • 封装微信小程序隐私信息授权
  • 【C#】FileInfo类 对文件进行操作
  • python中的字符串也是可迭代对象吗?
  • C++ 图像线特征提取【HoughLinesP算法】
  • Stable Diffusion WebUI内存不够爆CUDA Out of memory怎么办?
  • 模板学堂|数据可视化仪表板大屏设计流程梳理
  • 基于Xml方式Bean的配置-Bean的延时加载
  • python之pyQt5实例:Matplotlib的应用
  • 智囊AI-基于 ChatGPT 的 AI 工具产品 你的私人AI助手
  • nginx配置vue前端代理
  • 【C语言】【数据存储】用%u打印char类型?用char存128?
  • git-git命令汇总
  • 自定义实现简易版ArrayList
  • React中的Hooks--useReducer()
  • DM@数理逻辑@命题公式及其赋值@真值表@公式分类
  • HTTP协议(超级详细)
  • leetcode做题笔记135. 分发糖果
  • Oracle数据库体系结构(三)_逻辑结构
  • 在 Python 中计算两个 GPS 点之间的距离
  • 影刀RPA解决WPS不存在的问题
  • vue动态路由切换刷新保留历史路由搜索条件数据