博客
关于我
JAVA 最短连续无序子数组
阅读量:138 次
发布时间:2019-02-27

本文共 1582 字,大约阅读时间需要 5 分钟。

为了找到一个最短的连续子数组,使得对该子数组进行升序排序后,整个数组变为升序排序,我们可以采用以下方法:

  • 排序数组:首先,将原始数组排序,得到一个排序后的数组。
  • 确定子数组的开始位置:从左到右遍历原始数组,找到第一个不与排序后的数组对应的位置,这个位置即为子数组的开始位置。
  • 确定子数组的结束位置:从右到左遍历原始数组,找到第一个不与排序后的数组对应的位置,这个位置即为子数组的结束位置。
  • 计算子数组的长度:子数组的长度为结束位置减去开始位置再加一。
  • 详细步骤

  • 排序数组:创建一个排序后的数组sorted,并将其与原始数组nums排序。
  • 找到子数组的开始位置
    • 初始化start为-1。
    • 遍历数组nums,从左到右检查每个元素是否与排序后的数组sorted对应。如果发现不对应的元素,记录当前的索引start并结束遍历。
  • 找到子数组的结束位置
    • 初始化end为-1。
    • 从右到左遍历数组nums,检查每个元素是否与排序后的数组sorted对应。如果发现不对应的元素,记录当前的索引end并结束遍历。
  • 计算子数组的长度
    • 如果没有找到不对应的元素,说明整个数组已经是升序,返回0。
    • 否则,子数组的长度为end - start + 1
  • 代码实现

    import java.util.Arrays;public class Test1_28 {    public int findUnsortedSubarray(int[] nums) {        int[] sorted = Arrays.copyOf(nums, nums.length);        Arrays.sort(sorted);        int start = -1, end = -1;                for (int i = 0; i < nums.length; i++) {            if (sorted[i] != nums[i]) {                start = i;                break;            }        }                if (start == -1) {            return 0;        }                for (int i = nums.length - 1; i >= 0; i--) {            if (sorted[i] != nums[i]) {                end = i;                break;            }        }                return end - start + 1;    }        public static void main(String[] args) {        int[] nums = {2, 6, 4, 8, 10, 9, 15};        System.out.println(findUnsortedSubarray(nums));    }}

    解释

    • 排序数组:通过Arrays.sort(sorted)将原始数组排序,得到一个有序的数组sorted
    • 确定开始位置:从左到右遍历,找到第一个不匹配的位置start,这标志着子数组的开始。
    • 确定结束位置:从右到左遍历,找到第一个不匹配的位置end,这标志着子数组的结束。
    • 计算长度:子数组的长度通过end - start + 1计算得出。

    这种方法确保了在O(n log n)时间复杂度内解决问题,其中n是数组的长度,主要来自于排序操作。该算法有效地找到最短的子数组,确保排序该子数组后整个数组变为升序。

    转载地址:http://eqdd.baihongyu.com/

    你可能感兴趣的文章
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    oracle中关于日期问题的汇总!
    查看>>
    Oracle中常用的语句
    查看>>
    oracle中新建用户和赋予权限
    查看>>
    Oracle中的rownum 和rowid的用法和区别
    查看>>
    oracle中的大小写、字符、dual、数字、处理、日期、函数、显/隐式、时间、条件表达式case、decode、to_date、to_char、sysdate
    查看>>
    oracle典型安装失败,安装oracle 10失败
    查看>>
    Oracle监听配置、数据库实例配置等
    查看>>
    oracle系统 介绍,ORACLE数据库管理系统介绍
    查看>>
    oracle获取数据库表、字段、注释、约束等
    查看>>
    Oracle计划将ZGC项目提交给OpenJDK
    查看>>
    Oracle闪回技术(Flashback)
    查看>>
    oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
    查看>>
    oracle零碎要点---oracle em的web访问地址忘了
    查看>>
    Oracle零碎要点---多表联合查询,收集数据库基本资料
    查看>>
    Oracle静默安装
    查看>>
    Oracle面试题:Oracle中truncate和delete的区别
    查看>>
    TCP基本入门-简单认识一下什么是TCP
    查看>>