IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 【LeetCode笔记】581. 最短无序连续子数组(Java、数组) -> 正文阅读

[Java知识库]【LeetCode笔记】581. 最短无序连续子数组(Java、数组)

打卡第十五天~
前两天有事断签了,要继续加油噢!

题目描述

  • 主要是,需要达到 O(n) 复杂度。
    在这里插入图片描述

思路 && 代码

1. 排序法 O(nlogn)、O(n)

  • 诶,让我先来一个懒狗写法
  • 先 Arrays.sort 排序,然后有序数组、原数组逐个对比,找到需要进行排序的子数组头、尾元素即可。
class Solution {
    public int findUnsortedSubarray(int[] nums) {
        int len = nums.length;
        int[] copyArray = Arrays.copyOf(nums, len);
        // 时间复杂度 O(nlogn)
        Arrays.sort(copyArray);
        int left = 0;
        for(; left < len; left++) {
            if(nums[left] != copyArray[left]) {
                break;
            }
        }

        int right = len - 1;
        for(; right >= left; right--) {
            if(nums[right] != copyArray[right]) {
                break;
            }
        }

        return right - left + 1;
    }
}

2. 记录 max[ ]、min[ ] 的写法 O(n)、O(n)

  • 这个思路是,之前写的接雨水,还是啥长方形题目来着…用到的思路,这里刚好套用下。
  • min[i]:记录 i 右边的最小元素。如果 i 比这个元素大,说明 i 需要重排。
  • max[i]:记录 i 左边的最大元素。如果 i 比这个元素小,说明 i 需要重排。
    (实际代码复用 min数组)
class Solution {
    public int findUnsortedSubarray(int[] nums) {
        int len = nums.length;
        int[] min = new int[len];
        // 1. 先找 left
        // 尾元素右边没有值,直接设为自己
        min[len - 1] = nums[len - 1];
        for(int i = len - 2; i >= 0; i--) {
            min[i] = Math.min(nums[i + 1], min[i + 1]);
        }
        int left = len - 1;
        for(int i = 0; i < len; i++) {
            if(min[i] < nums[i]) {
                left = i;
                break;
            }
        }
        if(left == len - 1) {
            return 0;
        }

        // 2. 再找 right;
        min[0] = nums[0];
        for(int i = 1; i < len; i++) {
            min[i] = Math.max(nums[i - 1], min[i - 1]);
        }
        int right = 0;
        for(int i = len - 1; i >= 0; i--) {
            if(min[i] > nums[i]) {
                right = i;
                break;
            }
        }

        return right - left + 1;
    }
}

3. 记录 max、min 的写法 O(n)、O(1)

  • 算是方法2的优化吧,空间复杂度只有 O(1)
  • 总体思路一样,这里是没有 break
  • max:记录 i 左边的最大元素,如果 i 更小,说明 i 需要调整
  • min:记录 i 右边的最大元素,如果 i 更大,说明 i 需要调整
class Solution {
    public int findUnsortedSubarray(int[] nums) {
        int len = nums.length;
        if(len <= 1) {
            return 0;
        }

        // 1. 从左往右,记录最大值。如果 nums[i] < max,说明 i 需要调整
        int left = -1;
        int max = nums[0];
        for(int i = 1; i < len; i++) {
            max = Math.max(max, nums[i]);
            if(nums[i] < max) {
                left = i;
            }
        }

        // 2. 从右往左,记录最小值,同理
        int right = 0;
        int min = nums[len - 1];
        for(int i = len - 2; i >= 0; i--) {
            min = Math.min(min, nums[i]);
            if(nums[i] > min) {
                right = i;
            }
        }

        // left == -1 则说明整体有序,不用排序
        return left == -1 ? 0 : left - right + 1;
    }
}
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-08-02 10:40:39  更:2021-08-02 10:42:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年6日历 -2024/6/3 16:30:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码