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

题目:

思考:

  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;
    }
};
相关推荐
伟大的车尔尼2 天前
双指针题目:两数之和 IV - 输入二叉搜索树
二叉树··二叉搜索树·双指针
yaoh.wang3 天前
力扣(LeetCode) 88: 合并两个有序数组 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·双指针
yaoh.wang6 天前
力扣(LeetCode) 27: 移除元素 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·双指针
伟大的车尔尼6 天前
双指针题目:两个数组的交集 II
排序·双指针·哈希表
伟大的车尔尼9 天前
双指针题目:两个数组的交集
排序·双指针·哈希表
Chen--Xing10 天前
LeetCode 11.盛最多水的容器
c++·python·算法·leetcode·rust·双指针
lightqjx10 天前
【算法】双指针
c++·算法·leetcode·双指针
长安er13 天前
LeetCode876/141/142/143 快慢指针应用:链表中间 / 环形 / 重排问题
数据结构·算法·leetcode·链表·双指针·环形链表
程序员-King.13 天前
day122—二分查找—完成旅途的最少时间(LeetCode-2187)
算法·leetcode·二分查找·双指针
程序员-King.14 天前
day120—二分查找—统计公平数对的数目(LeetCode-2563)
算法·leetcode·二分查找·双指针