栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

581. 最短无序连续子数组

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

581. 最短无序连续子数组

文章目录

1.题目2.代码

1.题目

题目要求eg:

示例 1:

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

输入:nums = [1,2,3,4]
输出:0
示例 3:

输入:nums = [1]
输出:0

思路:使用辅助数组
新建一个跟原数组一摸一样的数组,然后排序。
从数组起始位置开始,两个数组相互比较,当对应位置数字不同的时候停止;
同理再从末尾开始,对应位置上比较,也是遇到不同的数字时停止,这样中间一段就是最短无序连续子数组了; 2.代码

class Solution {
public:
    int findUnsortedSubarray(vector& nums) {
    	int numbers=nums.size();
    	vector nums_copy=nums;
    	sort(nums_copy.begin(),nums_copy.end());
    	int i=0,j=numbers-1;
    	while (ii && nums[j]==nums_copy[j]) j--;
		return j-i+1;
    }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/718139.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号