博客
关于我
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/

你可能感兴趣的文章
Nginx多域名,多证书,多服务配置,实用版
查看>>
nginx如何实现图片防盗链
查看>>
Nginx学习总结(11)——提高Nginx服务器的安全性,稳定性和性能的12种技巧
查看>>
Nginx学习总结(12)——Nginx各项配置总结
查看>>
Nginx学习总结(13)——Nginx 重要知识点回顾
查看>>
Nginx学习总结(14)——Nginx配置参数详细说明与整理
查看>>
Nginx学习总结(15)—— 提升 Web 应用性能的十个步骤
查看>>
Nginx学习总结(8)——Nginx服务器详解
查看>>
nginx学习笔记002---Nginx代理配置_案例1_实现了对前端代码的方向代理_并且配置了后端api接口的访问地址
查看>>
Nginx安装SSL模块 nginx: the “ssl” parameter requires ngx_http_ssl_module in /usr/local/nginx/conf/nginx
查看>>
nginx安装stream模块配置tcp/udp端口转发
查看>>
nginx安装Stream模块配置tcp/udp端口转发
查看>>
Nginx安装与常见命令
查看>>
nginx安装与配置
查看>>
Nginx安装及配置详解
查看>>
nginx安装并配置实现端口转发
查看>>
nginx安装配置
查看>>
Nginx实战之1.1-1.6 Nginx介绍,安装及配置文件详解
查看>>
Nginx实战经验分享:从小白到专家的成长历程!
查看>>
nginx实现二级域名转发
查看>>