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

【C++题目】7.双指针_和为 s 的两个数字

文章目录

    • 题目链接:
    • 题目描述:
    • 解法
    • C++ 算法代码:
    • 图解


题目链接:

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


题目描述:

bf3710fc5731e7753df89b664e052d0e


解法

解法一(暴力解法,会超时)

两层 for 循环列出所有两个数字的组合,判断是否等于目标值。

外层 for 循环依次枚举第一个数 a

内层 for 循环依次枚举第二个数 b ,让它与 a 匹配;我们挑选第二个数的时候,可以不从第一个数开始选,因为 a 前面的数我们都已经在之前考虑过了。因此,我们可以从 a 往后的数开始列举。

然后将挑选的两个数相加,判断是否符合目标值。

解法二(双指针 - 对撞指针)

利用单调性,使用双指针算法解决问题

58526e9691445db584ed6c89e40aa5a5

如果2+21<30,那么2+7,2+11等等都不用计算了,因为肯定比2+21小。

left+right<tleft就要往后移动一位。

8722d00541ca322f6f486bacb06f4eb8

left+right<tleft往后移动一位。

686d41b3163332075d63cd7df736e5d9

left+right>tright往前移动一位。

78d39f526b9be96c8d1a5bef41da7dd3

left+right==t,返回结果。


C++ 算法代码:

解法一(暴力解法,会超时)

class Solution {
    public:
    vector<int> twoSum(vector<int>& nums, int target) {
        int n = nums.size();
        for (int i = 0; i < n; i++) { // 第一层循环从前往后列举第一个数
            for (int j = i + 1; j < n; j++) { // 第二层循环从 i 位置之后列举第二个数
                if (nums[i] + nums[j] == target) // 两个数的和等于目标值,说明我们已经找到结果了
                    return {nums[i], nums[j]};
            }
        }
        return {-1, -1};
    }
};

解法二(双指针 - 对撞指针)

class Solution 
{
public:
    vector<int> twoSum(vector<int>& nums, int target) 
    {
        int left = 0, right = nums.size() - 1;
        while(left < right)
        {
            int sum = nums[left] + nums[right];
            if(sum > target){
                right--;
            }
            else if(sum < target){
                left++;
            }
            else{
                return{nums[left], nums[right]};
            }
        }
        // 没有结果就照顾编译器,随便返回个东西。
        return {-4941, -1};
    }
};

图解

nums=[2,7,11,15,19,21],t=30

58526e9691445db584ed6c89e40aa5a5

  1. left=0,right=5

    left < right进入while循环

    sum=nums[0] + nums[5]=2+21=23<30

    left++;left=1

8722d00541ca322f6f486bacb06f4eb8

  1. left=1,right=5

    left < right进入while循环

    sum=nums[1] + nums[5]=7+21=28<30

    left++;left=2

686d41b3163332075d63cd7df736e5d9

  1. left=2,right=5

    left < right进入while循环

    sum=nums[2] + nums[5]=11+21=32>30

    right--;right=4

78d39f526b9be96c8d1a5bef41da7dd3

  1. left=2,right=4

    left < right进入while循环

    sum=nums[2] + nums[4]=11+19=30==30

    return{11, 19};

  2. 因为是顺序排列的,所以再次移动得到的不会刚好符合,或者得到的和本次一样,所以程序结束。


http://www.kler.cn/a/325700.html

相关文章:

  • 在 Webpack 中使用 预加载(Preloading) 技术可以通过动态导入(import())以及指定预加载的方式来进行优化
  • 《AI创造力的边界与机器人技术的现实困境:一个双重视角的探讨》
  • qt vs ios开发应用环境搭建和上架商店的记录
  • c语言 --- 字符串
  • 如何在Jupyter中快速切换Anaconda里不同的虚拟环境
  • vue3 uniapp封装一个瀑布流组件
  • Python | Leetcode Python题解之第447题回旋镖的数量
  • 【linux 多进程并发】linux进程状态与生命周期各阶段转换,进程状态查看分析,助力高性能优化
  • 【C++——文件操作】
  • Allen Institute for Artificial Intelligence (Ai2) 发布开源多模态语言模型 Molmo
  • Mixture-of-Experts (MoE): 条件计算的诞生与崛起【下篇】
  • 四十四、多云/混合云架构设计(安全与合规策略)
  • watchEffect工作原理
  • docker学习笔记(1.0)
  • 面经4——亚信
  • Visual Studio Code 高级使用技巧:插件推荐、调试技巧与工作流优化
  • 【HTML5】html5开篇基础(5)
  • 怎么屏蔽统计系统统计到的虚假ip
  • 【分布式微服务云原生】探索RPC:远程过程调用的奥秘与技术实现
  • 汽车信息安全 -- 再谈车规MCU的安全启动
  • 【小程序 - 大智慧】Expareser 组件渲染框架
  • CSS学习 - 常用属性
  • python自动更新chromedriver
  • ExpansionPanelList组件的用法
  • 【Android 14源码分析】Activity启动流程-2
  • 大模型使用vLLM推理加速