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

你找到的子数组应是最短的,请输出它的长度。

示例 1:

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

输入的数组长度范围在 [1, 10,000]。
输入的数组可能包含重复元素 ,所以升序的意思是<=。

class Solution {
public:int findUnsortedSubarray(vector<int>& nums) {if(nums.empty())return 0;int num = nums.size();int left = 0,right = 0;for(int i=0;i<num-1;++i){if(nums[i]>nums[i+1]){left = i;break;}}for(int i=num-1;i>0;--i){if(nums[i]<nums[i-1]){right = i;break;}}if(left==right)return 0;int min = INT_MAX,max = INT_MIN;for(int i=left;i<=right;++i){if(nums[i]<min)min = nums[i];if(nums[i]>max)max = nums[i];}int numleft = 0;for(int i=0;i<left;++i){if(nums[i]<=min)numleft++;}int numright = 0;for(int i=num-1;i>right;--i){if(nums[i]>=max)numright++;}return (num-numright-1)-numleft+1;}
};

最短无序连续子数组—leetcode581相关推荐

  1. LeetCode 581. 最短无序连续子数组 (unfinished 排序+双指针)

    581. 最短无序连续子数组 class Solution {public:int findUnsortedSubarray(vector<int>& nums) {vector& ...

  2. leetcode 581. 最短无序连续子数组(详解普通 / 进阶 / 单调栈解法,Java版)

    题目 题解 方法1(暴力排序):时间复杂度O(nlogn),空间复杂度O(n) 一个简单的想法是:将数组 nums 进行排序,记为 nums_sorted .然后比较 nums 和 nums_sort ...

  3. LeetCode 581. 最短无序连续子数组(排序单调栈)

    文章目录 1. 题目 2. 解题 2.1 排序 2.2 4次遍历 2.3 单调栈 1. 题目 给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序. ...

  4. leetcode 581. Shortest Unsorted Continuous Subarray | 581. 最短无序连续子数组(单调栈)

    题目 https://leetcode.com/problems/shortest-unsorted-continuous-subarray/ 题解 乍一看,没思路,直奔 Related Topics ...

  5. C#LeetCode刷题之#581-最短无序连续子数组( Shortest Unsorted Continuous Subarray)

    问题 给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序. 你找到的子数组应是最短的,请输出它的长度. 输入: [2, 6, 4, 8, 10, ...

  6. 581. 最短无序连续子数组 golang

    581. 最短无序连续子数组 给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序. 你找到的子数组应是最短的,请输出它的长度. 示例 1: 输入: ...

  7. 【LeetCode】【HOT】581. 最短无序连续子数组

    [LeetCode][HOT]581. 最短无序连续子数组 文章目录 [LeetCode][HOT]581. 最短无序连续子数组 package hot;public class Solution58 ...

  8. Leetcode 581.最短无序连续子数组

    最短无序连续子数组 给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序. 你找到的子数组应是最短的,请输出它的长度. 示例 1: 输入: [2, ...

  9. LeetCode 581. 最短无序连续子数组(Shortest Unsorted Continuous Subarray)

    581. 最短无序连续子数组 581. Shortest Unsorted Continuous Subarray 题目描述 给定一个整型数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序 ...

最新文章

  1. golang bufio.newscanner如何超时跳出_Golang微服务的熔断与限流
  2. 关于vue+element-ui项目的分页,返回默认显示第一页的问题解决
  3. python中怎么创建配置文件_在Python中创建游戏配置/选项(config.cfg)文件
  4. Hessian入门(与Spring集成)
  5. 关于眼界、眼光、眼前的哪些....
  6. python(matplotlib1)——figure图像,坐标设置
  7. 第四十五篇、UITableViewCell高度计算
  8. rename、remove
  9. 一篇文章搞懂数据仓库:数据仓库规范设计
  10. Linux命令行性能监控工具大全
  11. Python3 sorted() 与sort()函数
  12. 在VS2010中使用Git【图文】转
  13. 基于Debian的Linux发行版安装深度音乐及其插件,支持ubunut16
  14. 使用idea搭建Maven+SSM(Spring+SpringMVC+Mybatis)框架(一、使用Maven创建新工程)
  15. 信息集成项目管理工程师 学习资料_如何备考系统集成项目管理工程师?
  16. PPT模板文字环绕效果怎么设置?
  17. 小葵花妈妈课堂开课了:《ArrayList源码浅析》
  18. wifi共享大师,去除弹窗广告。
  19. 百利药业科创板上市:市值129亿 募资缩水4亿
  20. C#读取写入excel单元格

热门文章

  1. CTreeCtrl的用法
  2. python中迭代器和生成器的区别
  3. Centos 开机后,登录时无法输入密码怎么解决
  4. 爸爸我爱您(之十二)
  5. 【数据结构与算法】之深入解析“用Rand7()实现Rand10()”的求解思路与算法示例
  6. App设计灵感之十二组精美的外卖App设计案例
  7. GitHub之GitHub Actions的项目自动化持续集成和部署
  8. LeetCode 面试题 10.02. 变位词组
  9. EduCoder Linux文件/目录高级管理二
  10. Nginx URL 重写