最短无序连续子数组+双指针

题目:

思考:

  1. 我们要找到最短连续 子数组使得这个数组有序后整个nums有序
  2. 那么意味着 除了这个要找的数组以外的nums其余部分都已经有序
  3. 要使得这个数组长度最小,就要让这个数组前和数组后的原来的 有序部分最长
  4. 将nums分为三部分(nums1,nusm2,nums3)
  5. 可以知道nums1中最大的值要比nums2最小的值小(同理nums3最小的值要比nums2最大的值大)
  6. 利用这个性质得出nusm2的左右边界
  7. 从前往后遍历:维持一个最大值max_,遇到遍历值小于max_的时候说明这个值之前存在无序部分(也就是说这个值的位置pos是nums2的潜在右边界(为什么是潜在?因为要找最右边的无序位置)这样找到最右边的无序位置和最左的无序位置作为左右边界才能使得这个数组有序后整个nums有序)
  8. 从后往前遍历:同理不赘述

实现:

cpp 复制代码
class Solution {
public:
    int findUnsortedSubarray(vector<int>& nums) {

        int l=-1;
        int r=-1;

        int max_=INT_MIN;
        int min_=INT_MAX;


        
        for (int i=0;i<nums.size();i++)
        {
            if (nums[i]<max_)
            {
                l=i;
            }
            else
            {
                max_=nums[i];
            }
        }

        for (int i=nums.size()-1;i>=0;--i)
        {
            if (nums[i]>min_)
            {
                r=i;
            }
            else
            {
                min_=nums[i];
            }
        }


        return (l!=-1)?l-r+1:0;
    }
};

合并遍历搜索:

cpp 复制代码
class Solution {
public:
    int findUnsortedSubarray(vector<int>& nums) {

        int l=-1;
        int r=-1;

        int max_=INT_MIN;
        int min_=INT_MAX;


        
        for (int i=0;i<nums.size();i++)
        {
            if (nums[i]<max_)
            {
                l=i;
            }
            else
            {
                max_=nums[i];
            }

            if (nums[nums.size()-i-1]>min_)
            {
                r=nums.size()-i-1;
            }
            else
            {
                min_=nums[nums.size()-i-1];
            }

        }

        return (l!=-1)?l-r+1:0;
    }
};
相关推荐
小肝一下1 天前
每日两道力扣,day6
数据结构·c++·算法·leetcode·双指针·hot100
Byte不洛3 天前
LeetCode双指针经典题
c++·算法·leetcode·双指针
Fcy6483 天前
算法基础详解(4)双指针算法
开发语言·算法·双指针
Byte不洛9 天前
LeetCode中经典双指针题(环形链表 + 快乐数 + 移动零)
算法·leetcode·链表·数组·双指针
老四啊laosi15 天前
[双指针] 2. 力扣--复写零
算法·leetcode·双指针·复写零
汉克老师16 天前
GESP2026年3月认证C++五级( 第三部分编程题(2)找数)
c++·排序·双指针·二分算法·gesp5级·gesp五级
伟大的车尔尼17 天前
双指针题目:满足条件的子序列数目
二分查找·排序·双指针
旖-旎20 天前
二分查找(山脉数组的峰顶索引)(5)
c++·算法·leetcode·二分查找·力扣·双指针
旖-旎21 天前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
旖-旎23 天前
二分查找(1)
c++·算法·二分查找·力扣·双指针