最短無序連續(xù)子數組

題目描述
給定一個整數數組,你需要尋找一個連續(xù)的子數組,如果對這個子數組進行升序排序,那么整個數組都會變?yōu)樯蚺判颉?br> 你找到的子數組應是最短的,請輸出它的長度。

示例
輸入: [2, 6, 4, 8, 10, 9, 15]
輸出: 5
解釋: 你只需要對 [6, 4, 8, 10, 9] 進行升序排序,那么整個表都會變?yōu)樯蚺判颉?/p>

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);
    }
}
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容