博客
关于我
LeetCode 1574. 删除最短的子数组使剩余数组有序--二分长度
阅读量:741 次
发布时间:2019-03-21

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

  1. 删除最短的子数组使剩余数组有序
    给你一个整数数组 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

题解

二分区间长度,然后用vis[maxn][2]标记,vis[i][0]表示区间[0,i]是一个连续非递减区间,vis[i][1]表示[i,n]是一个连续非递减区间。

AC代码

class Solution {   public:    bool vis[100010][2];    bool check(int d,vector
arr) { if(vis[d][1])return true;//特判 if(vis[arr.size()-1-d][0])return true;//特判 for(int i=1;i+d
=arr[i-1]&&vis[i-1][0]&&vis[i+d][1])return true; } return false; } void init(vector
arr) { memset(vis,0,sizeof(vis)); vis[arr.size()-1][1]=true; for(int i=arr.size()-2;i>=0;i--) { if(arr[i]<=arr[i+1]) vis[i][1]=true; else break; } vis[0][0]=true; for(int i=1;i
=arr[i-1]) vis[i][0]=true; else break; } //for(int i=0;i
& arr) { int sign=-1; for(int i=1;i

在这里插入图片描述

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

你可能感兴趣的文章
Netty源码—8.编解码原理二
查看>>
Netty源码解读
查看>>
netty的HelloWorld演示
查看>>
Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
查看>>
Netty的网络框架差点让我一夜秃头,哭了
查看>>
Netty相关
查看>>
Netty简介
查看>>
Netty线程模型理解
查看>>
netty解决tcp粘包和拆包问题
查看>>
Netty速成:基础+入门+中级+高级+源码架构+行业应用
查看>>
Netty遇到TCP发送缓冲区满了 写半包操作该如何处理
查看>>
netty(1):NIO 基础之三大组件和ByteBuffer
查看>>
Netty:ChannelPipeline和ChannelHandler为什么会鬼混在一起?
查看>>
Netty:原理架构解析
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
Network 灰鸽宝典【目录】
查看>>
Network-Emulator Network-Emulator-Toolkit网络模拟器使用
查看>>
Networkx写入Shape文件
查看>>
NetworkX系列教程(11)-graph和其他数据格式转换
查看>>