题目
给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序。
你找到的子数组应是最短的,请输出它的长度。
- 示例 1:
输入: [2, 6, 4, 8, 10, 9, 15]
输出: 5 - 解释: 你只需要对 [6, 4, 8, 10, 9] 进行升序排序,那么整个表都会变为升序排序。
- 说明 :
输入的数组长度范围在 [1, 10,000]。
输入的数组可能包含重复元素 ,所以升序的意思是<=。
解题思路
- 创建一个新数组,将原来的数组升序排序
- 比较两个数组中的元素是否一致,采用双指针
- 时间复杂度为O(n), 空间复杂度为O(n)
代码
class Solution(object):
def findUnsortedSubarray(self, nums):
nums_sort = sorted(nums)
n = len(nums)
start = 0
end = n - 1
while start <= end and nums[start] == nums_sort[start]:
start +=1
while start <= end and nums[end] == nums_sort[end]:
end -=1
return end - start + 1