美文网首页算法代码
最短无序连续子数组

最短无序连续子数组

作者: windUtterance | 来源:发表于2020-11-18 09:39 被阅读0次

    题目描述
    给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序。
    你找到的子数组应是最短的,请输出它的长度。

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

    Java代码

    class Solution {
        public int findUnsortedSubarray(int[] nums) {
            int[] new_nums = nums.clone();
            Arrays.sort(new_nums);
            int start = new_nums.length, end = 0;
    
            for(int i = 0;i < nums.length;i++) {
                if(new_nums[i] != nums[i]) {
                    start = Math.min(start, i);
                    end = Math.max(end, i);
                }
            }
    
            return (end - start >= 0? end - start + 1 : 0);
        }
    }
    

    相关文章

      网友评论

        本文标题:最短无序连续子数组

        本文链接:https://www.haomeiwen.com/subject/xakgektx.html