題目描述:
給定一個整數數組,你需要尋找一個連續(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);
}
}