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

LCR 179. 查找总价格为目标值的两个商品 - 力扣

1. 题目

购物车内的商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况,返回任一结果即可。

2. 示例

3. 分析 

题目有说明为递增数组,所以可以利用单调性+双指针解决。跟611. 有效的三角形个数为一类题目。

解题方法:

先定义两个指针指向数组左右,它们的和有三种情况:

  • sum > target
    price[right]为数组内的最大值,price[left]为最小,所以此时[left+1, right-1]这个区间的数分别加上price[right]的和是肯定会超过target的,因为题目已经说明数组为递增的最小加上最大都大于target,所以price[left] (最小)右边区间的数也肯定会大于target了。所以直接舍弃掉此时的最小值,再left++即可。
  • sum < target
    price[right]为数组内的最大值,price[left]为最小,所以此时[left+1, right-1]这个区间的数分别加上price[left]的和是肯定不会超过target的,因为题目已经说明数组为递增的,最小加上最大都没有大于target,所以price[right] (最大)左边区间的数也肯定会小于target了。所以直接舍弃掉此时的最大值,再right--即可。
  • sum == target
    返回结果即可

class Solution {
public:vector<int> twoSum(vector<int>& price, int target) {int left = 0, right = price.size()-1;while (left < right){int sum = price[left] + price[right];if (sum > target) right--;else if (sum < target) left++;else return {price[left], price[right]};}return {-1, -1};// 题目莫得要求无结果需返回什么,所以随便返回两个负数即可}
};
http://www.lryc.cn/news/313616.html

相关文章:

  • 《汇编语言》- 读书笔记 - 第16章-直接定址表
  • ChatGPT 新增朗读功能,支持 37 种语言
  • 洛谷 P8816 [CSP-J 2022] 上升点列(T4)
  • python爬虫(2)
  • 外包干了8天,技术退步明显。。。。。
  • 浅谈去耦电容的作用、选择、布局及其它电容的区别!
  • 抖音视频评论批量采集软件|视频下载工具
  • javaSE-----继承和多态
  • 数据库之Oracle数据导入导出
  • nRF52832——GPIOTE与外部中断
  • 根据用户名称实现单点登录
  • 【设计】855. 考场就座
  • Android中的传感器类型和接口名称
  • 解析进程 /proc/pid/maps 和 /proc/pid/smaps
  • 【MQ】消息队列概述
  • 交友盲盒系统PHP开源的盲盒源码
  • 【Flutter 面试题】什么是异步编程 Flutter中如何处理异步操作?
  • 处理error: remote origin already exists.及其Gitee文件上传保姆级教程
  • 网络编程套接字(2)——Socket套接字
  • 向量错题本
  • FPGA-VGA成像原理与时序
  • 【VTKExamples::Points】第三期 ExtractClusters
  • 迅速上手:CentOS 系统下 SSH 服务配置指南
  • day38 动态规划part1
  • 01背包问题 刷题笔记
  • docker安装包(Linux和windows)
  • RabbitMQ 安装使用
  • echarts x轴名称过长tip显示全称
  • js和css阻塞问题
  • MySQL 的基础操作