【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;
};
相关推荐
!停11 分钟前
C语言单链表
c语言·数据结构·算法
独自破碎E14 分钟前
【队列】求二叉树的层序遍历
leetcode
闻缺陷则喜何志丹22 分钟前
【回文 字符串】3677 统计二进制回文数字的数目|2223
c++·算法·字符串·力扣·回文
Tisfy29 分钟前
LeetCode 0085.最大矩形:单调栈
算法·leetcode·题解·单调栈
mit6.82430 分钟前
出入度|bfs|状压dp
算法
hweiyu0031 分钟前
强连通分量算法:Kosaraju算法
算法·深度优先
源代码•宸31 分钟前
Golang语法进阶(定时器)
开发语言·经验分享·后端·算法·golang·timer·ticker
mit6.82438 分钟前
逆向思维|memo
算法
机器学习之心39 分钟前
MATLAB灰狼优化算法(GWO)改进物理信息神经网络(PINN)光伏功率预测
神经网络·算法·matlab·物理信息神经网络
代码游侠43 分钟前
学习笔记——ESP8266 WiFi模块
服务器·c语言·开发语言·数据结构·算法