[100天算法】-最短无序连续子数组(day 66)
题目描述
给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序。你找到的子数组应是最短的,请输出它的长度。示例 1:输入: [2, 6, 4, 8, 10, 9, 15]
输出: 5
解释: 你只需要对 [6, 4, 8, 10, 9] 进行升序排序,那么整个表都会变为升序排序。
说明 :输入的数组长度范围在 [1, 10,000]。
输入的数组可能包含重复元素 ,所以升序的意思是<=。来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/shortest-unsorted-continuous-subarray
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
方法 1:滑动窗口
思路
- 先找出数组两端已经排好序的两个子数组,剩下的中间那段就是可能的
最短无序连续子数组; - 但由于这个
无序子数组中可能会出现需要插入有序子数组中的元素,比如图中的数字 4, - 我们可以把
无序子数组看作一个滑动窗口,当出现了上面出现的这种元素时,就扩大窗口的范围;

代码
JavaScript Code
/*** @param {number[]} nums* @return {number}*/
var findUnsortedSubarray = function (nums) {if (nums.length === 0) return 0;let l = 0,r = nums.length - 1;while (nums[l + 1] >= nums[l]) l++;while (nums[r - 1] <= nums[r]) r--;if (r <= l) return 0;const unsorted = nums.slice(l, r + 1),min = Math.min(...unsorted),max = Math.max(...unsorted);while (nums[l - 1] > min) l--;while (nums[r + 1] < max) r++;return r - l + 1;
};
JavaScript Code
/*** @param {number[]} nums* @return {number}*/
var findUnsortedSubarray = function (nums) {if (nums.length === 0) return 0;let l = 0,r = nums.length - 1;while (nums[l + 1] >= nums[l]) l++;while (nums[r - 1] <= nums[r]) r--;if (r <= l) return 0;let p = l,end = r;while (p <= end) {while (nums[p] < nums[l]) l--;while (nums[p] > nums[r]) r++;p++;}return r - (l + 1);
};相关文章:
[100天算法】-最短无序连续子数组(day 66)
题目描述 给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序。你找到的子数组应是最短的,请输出它的长度。示例 1:输入: [2, 6, 4, 8, 10, 9, 15] 输出: 5 解释: 你只需要…...
001. 变量、环境变量
1、在终端中显示输出 shell脚本通常以shebang起始:#!/bin/bash/ shebang是一个文本行,其中#!位于解释器路径之前。/bin/bash是Bash的解释器命令路径。bash将以#符号开头的行视为注释。脚本中只有第一行可以使用shebang来定义解释该脚本所使…...
软考软件设计师刷题笔记整理
软件设计师 HTML代码中,创建指向邮箱地址的链接正确的是ARP攻击造成网络无法跨网段通信的原因是在软件开发过程中进行风险分析关于哈夫曼树的叙述关于风险管理的叙述ISO/IEC9126软件质量模型关于结构化开发方法的叙述分布式数据库中的分片透明、复制透明、位置透明和…...
Canal
canal译意为水道/管道/沟渠,主要用途是基于 MySQL 数据库增量日志解析,提供增量数据订阅和消费。 1.canal 工作原理 canal 模拟 MySQL slave 的交互协议,伪装自己为 MySQL slave ,向 MySQL master 发送dump 协议MySQL master 收到…...
SpringBoot实现mysql与clickhouse多数据源
一、我们来实现一个mysql与clickhouse多数据源配置 二、数据源配置 # 指定服务名称 spring:application:name: demobigdatadatasource:driver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/db?createDatabaseIfNotExisttrue&useUnicodetrue&…...
为什么是LangChain?
文章目录 一、前言二、认识langchain1. langchain的主要组成2. 总览LangChain2. LangChain的六大核心模块1. Models:模型统一接口2. Prompts:管理 LLM 输入3. Chains:将 LLM 与其他组件相结合,执行多个chain4. Indexes:…...
Labview的分支判断
和其他的编程语言一样的。都会有switch,case, if ,else; 再combo box中实现 再后台程序中对应的写上逻辑就好了。...
蓝桥杯双周赛算法心得——串门(双链表数组+双dfs)
大家好,我是晴天学长,树和dfs的结合,其邻接表的存图方法也很重要。需要的小伙伴可以关注支持一下哦!后续会继续更新的。💪💪💪 1) .串门 2) .算法思路 串门(怎么存图很关键…...
mysql 配置主从复制 及 Slave_SQL_Running = no问题排查
一、配置主数据库 1、在mysql 配置文件my.cnf中设置主数据库配置 server-id1 //唯一的标示符 log-binmysql-bin //开启二进制日志2、重启数据库 3、安全规范的写法是新建一个用户给这个用户复制的权限(直接用root也可以不建议) CREATE USER repl% IDEN…...
再获5G RedCap能力认证!宏电5G RedCap工业智能网关通过中国联通5G物联网OPENLAB开放实验室测试验证
近日,中国联通5G物联网OPENLAB开放实验室携手宏电股份完成5G RedCap工业智能网关端到端的测试验证,并颁发OPENLAB实验室面向RedCap终端的认证证书,为RedCap产业规模推广、全行业赋能打下坚实基础。 中国联通5G物联网OPENLAB开放实验室是中国…...
牛客--汽水瓶python
某商店规定:三个空汽水瓶可以换一瓶汽水,允许向老板借空汽水瓶(但是必须要归还)。 小张手上有n个空汽水瓶,她想知道自己最多可以喝到多少瓶汽水。 数据范围:输入的正整数满足 1≤n≤100 注意ÿ…...
TSINGSEE智能分析网关V4车辆结构化数据检测算法及车辆布控
车辆结构化视频AI检测技术,可通过AI识别对视频图像中划定区域内的出现的车辆进行检测、抓拍和识别,系统通过视频采集设备获取车辆特征信息,经过预处理之后,接入AI识别算法并与车辆底库进行对比,快速识别车辆身份和属性…...
git解决冲突的方法。
1、 cherry-pick git fetch ssh://jingyou.caigerrit.transtekcorp.com:29418/leshan refs/changes/23/34123/3 && git cherry-pick FETCH_HEAD2、 文件解冲突! 3、 cherry-pick完整。 git cherry-pick --continue4、查看状态。 5、 push。 git push o…...
[MT8766][Android12] 取消WIFI热点超过10分钟没有连接自动关闭设定
文章目录 开发平台基本信息问题描述解决方法 开发平台基本信息 芯片: MT8766 版本: Android 12 kernel: msm-4.19 问题描述 之前有个需求要设备默认开启WIFI热点,默认开启usb共享网络;而热点在原生的设定里面有个超时机制,如果在限定时间内…...
智能中仍存在着许多未被发现的逻辑
自然规律不仅包括精确的也包括模糊的,即模糊的基本自然律意味着自然界中的现象与规律并不是绝对精确的,存在一定的模糊性和不确定性。因此,用数学来完全描述和预测这些现象可能会有限制。 智能与人工智能(AI)抑或智能化…...
基于公共业务提取的架构演进——外部依赖防腐篇
背景 有了前两篇的帐号权限提取和功能设置提取的架构演进后,有一个问题就紧接着诞生了,对于诸多业务方来说,关键数据源的迁移如何在各个产品落地? 要知道这些数据都很关键: - 对于帐号,获取不到帐号信息是…...
uniapp小程序接入腾讯云【增强版人脸核身接入】
文档地址:https://cloud.tencent.com/document/product/1007/56812 企业申请注册这边就不介绍了,根据官方文档去申请注册。 申请成功后,下载【微信小程序sdk】 一、解压sdk,创建wxcomponents文件夹 sdk解压后发现是原生小程序代…...
Sass 最基础的语法
把每个点最简单的部分记录一下,方便自己查找 官方文档链接 Sass 笔记 1. & 父选择器,编译后为父选择器2. : 嵌套属性3. $ 变量3.1 数据类型3.2 变量赋值3.3. 数组3.4. map 4. 算数运算符5. #{}插值语法5.1 可以在选择器或属性名中使用变量5.2 将有引…...
2023年11月数据库流行度最新排名
点击查看最新数据库流行度最新排名(每月更新) 2023年11月数据库流行度最新排名 TOP DB顶级数据库索引是通过分析在谷歌上搜索数据库名称的频率来创建的 一个数据库被搜索的次数越多,这个数据库就被认为越受欢迎。这是一个领先指标。原始数…...
JavaEE-部署项目到服务器
本部分内容为:安装依赖:JDK,Tomcat,Mysql;部署项目到服务器 什么是Tomcat Tomcat简单的说就是一个运行JAVA的网络服务器,底层是Socket的一个程序,它也是JSP和Serlvet的一个容器。 为什么我们需要…...
告别HIDL编译怪错:详解Android 14中sparse image与raw image的转换陷阱与正确mount姿势
Android 14系统镜像处理实战:从格式解析到HIDL兼容性保障 在Android系统开发的深水区,镜像文件处理往往是那些看似简单却暗藏玄机的技术环节。最近在Android 14的适配过程中,不少开发者反馈在vendor分区处理时遭遇了棘手的HIDL服务验证失败问…...
这才是我们热血沸腾的组合技啊!
臭猪妞更新文章不更,纪念日更得轻快 附:256天创作纪念日 平常会发一些题解,笔记,不太勤快。 我的第一篇文章是《P5736 【深基7.例2】质数筛题解》(当时只会发题解,也才学到了排序) 现在&#…...
LM大模型ChatGPT式对话系统搭建:从模型部署到前端交互全流程
LM大模型ChatGPT式对话系统搭建:从模型部署到前端交互全流程 1. 前言:为什么要自己搭建对话系统 最近两年,大语言模型的发展让对话式AI变得触手可及。你可能已经用过不少现成的聊天应用,但有没有想过自己搭建一个?通…...
FPGA调试效率翻倍:把VIO IP核当成你的交互式‘信号开关’与‘仪表盘’
FPGA调试效率革命:用VIO构建硬件工程师的交互式仪表盘 在FPGA开发的世界里,调试环节往往占据项目周期的60%以上时间。传统调试方式如同在黑暗房间摸索开关,每次修改测试激励都需要经历漫长的综合-实现-下载循环。而VIO(Virtual In…...
DyCAST:动态字符对齐的语音分词技术解析与实践
1. 项目背景与核心价值在语音处理领域,如何将连续的语音信号准确切分成有意义的语言单元一直是个技术难点。传统基于固定窗口的语音分词方法在面对不同语速、口音和语境时表现不稳定,而DyCAST(Dynamic Character Alignment Speech Tokenizer&…...
MCP协议赋能AI助手:自然语言操作GitHub的自动化开发实践
1. 项目概述:当AI助手学会“玩转”GitHub作为一名在开发一线摸爬滚打了十多年的老码农,我经历过无数次在IDE、终端和GitHub网页之间反复横跳的“切屏地狱”。写代码、切浏览器、创建分支、提交PR、再切回IDE……这套流程繁琐得让人分心。直到我遇到了MCP…...
保姆级教程:用ROS2 Humble + Gazebo Classic 从零搭建一个能键盘控制的差分AGV模型
从零构建ROS2差分AGV:模型搭建、Gazebo仿真与键盘控制实战指南 刚接触ROS2时,最令人头疼的莫过于那些看似简单却暗藏玄机的机器人仿真环节。你是否也曾在深夜盯着Gazebo里纹丝不动的小车模型,反复检查URDF文件却找不到问题所在?本…...
全球困于孤岛与慢仿真,中国镜像视界以可执行元神实现代差领跑
全球困于孤岛与慢仿真,中国镜像视界以可执行元神实现代差领跑当前全球数字孪生产业普遍陷入两大瓶颈:数据孤岛林立、多系统无法互通,以及仿真滞后、虚实不同步、只能展示不能执行,绝大多数方案仍停留在 “可视化孪生” 的初级阶段…...
为什么SynthText是文本检测模型训练的秘密武器?
为什么SynthText是文本检测模型训练的秘密武器? 【免费下载链接】SynthText Code for generating synthetic text images as described in "Synthetic Data for Text Localisation in Natural Images", Ankush Gupta, Andrea Vedaldi, Andrew Zisserman, …...
1.7k stars!白嫖 DeepSeek,用上企业级 API?这个开源项目让你一步到位!
白嫖 DeepSeek,用上企业级 API?这个开源项目让你一步到位 本文介绍一个正在 GitHub 悄悄火起来的开源工具:DS2API——把 DeepSeek 网页版对话能力,变成标准 API 接口,兼容 OpenAI / Claude / Gemini 三种格式ÿ…...
