优选算法——双指针6(单调性)

🔥近津薪荼:个人主页

🎬个人专栏:《c语言基础知识详解》《c++基础知识详解》

❄️莫问几时见天明

✨休管他人论长短


本期知识点导图

1.上期参考代码:

cpp 复制代码
class Solution {
public:
    int xxjshitiancai(vector<int>& nums) {
        sort(nums.begin(), nums.end());//先排序~
        int sum = 0, n = nums.size();
        
        for (int i = n - 1; i >= 2; i--) {
            int left = 0, right = i - 1;//每一次遍历双指针的初始位置
            while (left < right) {
                if (nums[left] + nums[right] > nums[i]) {
                    sum += right - left;
                    right--;
                } else {
                    left++;
                }
            }
        }
        return sum;
    }
};

放一只乌萨奇在这,有什么不懂的尽管问他~

2.题目解析

LCR 179. 查找总价格为目标值的两个商品(点击跳转)

重点:

升序

要找一个二元组,他俩之和满足目标值

返回任一结果即可

3.思路讲解

3.1暴力解法:

穷举出所有组合,直到找到符合要求的组合。

循环嵌套,时间复杂度O(N^2),会超时(比较简单,就不再赘述啦,有问题的同学可以看前几期的暴力解法~)

3.2优解:

思路:

  • 看到有序数组,又是找指定二元组,不难想到双指针和单调性

不难想到的,对吧

  • 就题给示例:

因为升序,left之后的值都比left大,但是最小值left与此right相加都大于目标值,那么在此[left,right]区间里,剩下的值与此right相加必然大于目标值**(单调性)**,那么left向右遍历没有意义,因此我们让right--

在新的区间内再次进行如上逻辑判断,直至找到和为目标值的二元组。

今天的题非常之简单,相信有不少新手同学第一次做都能自己把它做出来。

劝敲:

4.预告

下一篇要讲解的题为
三数之和(点击跳转)

思路与本题有千丝万缕的关系,

大家可以顺着这题的思路来做一做。

明天见~

相关推荐
会周易的程序员13 分钟前
cNetgate物联网网关内存数据表和数据视图模块架构
c语言·c++·物联网·架构·lua·iot
Jason_Honey228 分钟前
【平安Agent算法岗面试-二面】
人工智能·算法·面试
宇木灵37 分钟前
C语言基础-十、文件操作
c语言·开发语言·学习
程序员酥皮蛋39 分钟前
hot 100 第三十五题 35.二叉树的中序遍历
数据结构·算法·leetcode
追随者永远是胜利者42 分钟前
(LeetCode-Hot100)207. 课程表
java·算法·leetcode·go
云泽8081 小时前
C++ 多态入门:虚函数、重写、虚析构及 override/final 实战指南(附腾讯面试题)
开发语言·c++
仰泳的熊猫1 小时前
题目1535:蓝桥杯算法提高VIP-最小乘积(提高型)
数据结构·c++·算法·蓝桥杯
那起舞的日子2 小时前
动态规划-Dynamic Programing-DP
算法·动态规划
闻缺陷则喜何志丹2 小时前
【前后缀分解】P9255 [PA 2022] Podwyżki|普及+
数据结构·c++·算法·前后缀分解
每天吃饭的羊2 小时前
时间复杂度
数据结构·算法·排序算法