【LeetCode每日一题】单调栈 581. 最短无序连续子数组

581. 最短无序连续子数组

给你一个整数数组 nums ,你需要找出一个 连续子数组 ,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序。

请你找出符合题意的 最短 子数组,并输出它的长度。

示例 1:

复制代码
输入:nums = [2,6,4,8,10,9,15]
输出:5
解释:你只需要对 [6, 4, 8, 10, 9] 进行升序排序,那么整个表都会变为升序排序。

示例 2:

复制代码
输入:nums = [1,2,3,4]
输出:0

示例 3:

复制代码
输入:nums = [1]
输出:0

方法一:

  • 拷贝一份数组,对新数组进行排序
  • 利用双指针遍历数组,找到与原数组不同顺序的数组,用left 和 right 标记。

方法二:利用单调栈


js 复制代码
/**
 * @param {number[]} nums
 * @return {number}
 */
var findUnsortedSubarray = function(nums) {
    if(nums.length === 1){
        return 0;
    }

    // 从左到右构造一个单调递增的栈
    let left = nums.length - 1;
    let stack1 = [];
    for(let i = 0; i < nums.length; i++){
        while(stack1.length && nums[i] < nums[stack1.at(-1)]){
            left = Math.min(left, stack1.pop());
        }
        stack1.push(i);
    }

    // 从右到左构造一个单调递减的栈
    let right = 0;
    let stack2 = [];
    for(let i = nums.length - 1; i >= 0; i--){
        while(stack2.length && nums[i] > nums[stack2.at(-1)]){
            right = Math.max(right, stack2.pop());
        }
        stack2.push(i);
    }
    return left > right ? 0 : right - left + 1;
};
相关推荐
老鼠只爱大米1 分钟前
LeetCode经典算法面试题 #199:二叉树的右视图(BFS双队列法、DFS递归法等多种实现方案详细解析)
算法·leetcode·二叉树·dfs·bfs·深度优先搜索·右视图
历程里程碑3 分钟前
子串-----和为 K 的子数组
java·数据结构·c++·python·算法·leetcode·tornado
一起养小猫4 分钟前
Flutter for OpenHarmony 进阶:表达式解析算法与计算器核心实现
算法·flutter·harmonyos
池央10 分钟前
贪心-最长递增子序列
算法·贪心算法
We་ct14 分钟前
LeetCode 383. 赎金信:解题思路+代码解析+优化实战
前端·算法·leetcode·typescript
不懒不懒25 分钟前
【逻辑回归从原理到实战:正则化、参数调优与过拟合处理】
人工智能·算法·机器学习
一只大袋鼠26 分钟前
分布式 ID 生成:雪花算法原理、实现与 MyBatis-Plus 实战
分布式·算法·mybatis
tobias.b29 分钟前
408真题解析-2010-27-操作系统-同步互斥/Peterson算法
算法·计算机考研·408真题解析
寄存器漫游者38 分钟前
数据结构 二叉树核心概念与特性
数据结构·算法
m0_7066532341 分钟前
跨语言调用C++接口
开发语言·c++·算法