LeetCode 581. 最短无序连续子数组

题目

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

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

  • 示例 1:
    输入: [2, 6, 4, 8, 10, 9, 15]
    输出: 5
  • 解释: 你只需要对 [6, 4, 8, 10, 9] 进行升序排序,那么整个表都会变为升序排序。
  • 说明 :
    输入的数组长度范围在 [1, 10,000]。
    输入的数组可能包含重复元素 ,所以升序的意思是<=。
解题思路
  1. 创建一个新数组,将原来的数组升序排序
  2. 比较两个数组中的元素是否一致,采用双指针
  3. 时间复杂度为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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。