当前位置: 首页 > news >正文

【算法题】1574. 删除最短的子数组使剩余数组有序

插: 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。
坚持不懈,越努力越幸运,大家一起学习鸭~~~

题目:

给你一个整数数组 arr ,请你删除一个子数组(可以为空),使得 arr 中剩下的元素是 非递减 的。

一个子数组指的是原数组中连续的一个子序列。

请你返回满足题目要求的最短子数组的长度。

示例 1:

输入:arr = [1,2,3,10,4,2,3,5]
输出:3
解释:我们需要删除的最短子数组是 [10,4,2] ,长度为 3 。剩余元素形成非递减数组 [1,2,3,3,5] 。
另一个正确的解为删除子数组 [3,10,4] 。
示例 2:

输入:arr = [5,4,3,2,1]
输出:4
解释:由于数组是严格递减的,我们只能保留一个元素。所以我们需要删除长度为 4 的子数组,要么删除 [5,4,3,2],要么删除 [4,3,2,1]。
示例 3:

输入:arr = [1,2,3]
输出:0
解释:数组已经是非递减的了,我们不需要删除任何元素。
示例 4:

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

提示:

1 <= arr.length <= 10^5
0 <= arr[i] <= 10^9

java代码:

class Solution { // 模板二
    public int findLengthOfShortestSubarray(int[] arr) {
        int n = arr.length;
        int i = 1, j = n-1;
        while (i<n && arr[i-1]<=arr[i]) ++i;
        if (i == n) return 0; // arr已经有序
        while (j-1>=0 && arr[j-1]<=arr[j]) --j;
        int l = j, r = n-1; 
        int ans = j; // 最坏结果只保留right
        for (int k = 0; k < i; ++k) {
            int target = arr[k];
            l = j; r = n; //搜索right区间[j,n-1]
            while (l<r) {
                int mid = (l+r)>>1;
                if (arr[mid] < target) {
                    l = mid+1;
                } else {
                    r = mid;
                }
            }
            ans = Math.min(ans, r-k-1);
        }
        return ans;
    }
}

相关文章:

  • 考虑电能交互的冷热电区域多微网系统双层多场景协同优化配置(Matlab代码实现)
  • 【openEuler】内核热升级
  • echarts省市区id(区域编码)实现地图下钻点击(data赋值自定义属性值,geojson信息获取)
  • 大数据面试题集锦-Hadoop面试题(二)-HDFS
  • 类与类之间关系的表示方式
  • MacBook Pro外接显示器竖屏显示
  • 三网折扣话费充值接口文档
  • 8 个精彩的免费 G​​IS 软件资源分享
  • Spring之事务编程概述
  • 测试开发 | 想测试入门就必须要懂的软件开发流程
  • 常用windows自带程序对应的命令
  • Redis底层数据结构简介
  • 小型水库雨水情测报和安全监测解决方案
  • vs最常用快捷键
  • ES6学习笔记之尾调用
  • 数据结构刷题(四):203移除链表元素、707设计链表、206反转链表
  • MyBatis -- 多表查询
  • 【Java|golang】1814. 统计一个数组中好对子的数目
  • Cookie 会话身份验证是如何工作的?
  • 加油站视频监控智能分析盒基于yolov5