LeetCode 2970.统计移除递增子数组的数目 I:深夜刷题之——50的数据n^3暴力秒了

【LetMeFly】2970.统计移除递增子数组的数目 I:深夜刷题之——50的数据n^3暴力秒了

力扣题目链接:https://leetcode.cn/problems/count-the-number-of-incremovable-subarrays-i/

给你一个下标从 0 开始的  整数数组 nums 。

如果 nums 的一个子数组满足:移除这个子数组后剩余元素 严格递增 ,那么我们称这个子数组为 移除递增 子数组。比方说,[5, 3, 4, 6, 7] 中的 [3, 4] 是一个移除递增子数组,因为移除该子数组后,[5, 3, 4, 6, 7] 变为 [5, 6, 7] ,是严格递增的。

请你返回 nums 中 移除递增 子数组的总数目。

注意 ,剩余元素为空的数组也视为是递增的。

子数组 指的是一个数组中一段连续的元素序列。

 

示例 1:

输入:nums = [1,2,3,4]
输出:10
解释:10 个移除递增子数组分别为:[1], [2], [3], [4], [1,2], [2,3], [3,4], [1,2,3], [2,3,4] 和 [1,2,3,4]。移除任意一个子数组后,剩余元素都是递增的。注意,空数组不是移除递增子数组。

示例 2:

输入:nums = [6,5,7,8]
输出:7
解释:7 个移除递增子数组分别为:[5], [6], [5,7], [6,5], [5,7,8], [6,5,7] 和 [6,5,7,8] 。
nums 中只有这 7 个移除递增子数组。

示例 3:

输入:nums = [8,7,6,6]
输出:3
解释:3 个移除递增子数组分别为:[8,7,6], [7,6,6] 和 [8,7,6,6] 。注意 [8,7] 不是移除递增子数组因为移除 [8,7] 后 nums 变为 [6,6] ,它不是严格递增的。

 

提示:

  • 1 <= nums.length <= 50
  • 1 <= nums[i] <= 50

解题方法:暴力模拟

写一个函数判断nums数组除了[l, r]的部分是否是严格递增的:

使用一个变量last记录上一个遍历到的数(初始值是“极小值”0),

遍历nums数组的每个元素:

若当前下标i[l, r]范围内,则跳过;

否则,若nums[i] <= last,返回false

last = nums[i]

遍历结束未返回false则返回true

这样,我们就可以从0到len(nums) - 1枚举左端点l,从llen(nums) - 1枚举右边端点r,调用函数判断移除[l, r]区间后是否未严格递增数组,若是则累加到答案中。

  • 时间复杂度 O ( l e n ( n u m s ) 3 ) O(len(nums)^3) O(len(nums)3)
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
class Solution {
private:bool isOk(vector<int>& nums, int l, int r) {int last = 0;for (int i = 0; i < nums.size(); i++) {if (l <= i && i <= r) {continue;}if (nums[i] <= last) {return false;}last = nums[i];}return true;}
public:int incremovableSubarrayCount(vector<int>& nums) {int ans = 0;for (int l = 0; l < nums.size(); l++) {for (int r = l; r < nums.size(); r++) {ans += isOk(nums, l, r);}}return ans;}
};
Go
package mainfunc isOk(nums []int, l int, r int) int {last := 0for i := 0; i < len(nums); i++ {if l <= i && i <= r {continue}if nums[i] <= last {return 0}last = nums[i]}return 1
}func incremovableSubarrayCount(nums []int) int {ans := 0for l := 0; l < len(nums); l++ {for r := l; r < len(nums); r++ {ans += isOk(nums, l, r)}}return ans
}
Java
class Solution {private boolean isOk(int[] nums, int l, int r) {int last = 0;for (int i = 0; i < nums.length; i++) {if (l <= i && i <= r) {continue;}if (nums[i] <= last) {return false;}last = nums[i];}return true;}public int incremovableSubarrayCount(int[] nums) {int ans = 0;for (int l = 0; l < nums.length; l++) {for (int r = l; r < nums.length; r++) {ans += isOk(nums, l, r) ? 1 : 0;}}return ans;}
}
Python
from typing import Listclass Solution:def isOk(self, l: int, r: int) -> bool:last = 0for i in range(len(self.nums)):if l <= i <= r:continueif self.nums[i] <= last:return Falselast = self.nums[i]return Truedef incremovableSubarrayCount(self, nums: List[int]) -> int:self.nums = numsans = 0for l in range(len(nums)):for r in range(l, len(nums)):ans += self.isOk(l, r)return ans

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

Tisfy:https://letmefly.blog.csdn.net/article/details/140310063

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/44093.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

软件缺陷简介

缺陷种类 遗漏&#xff0c;指规定或预期的需求为体现在产品种错误&#xff0c;需求是明确的&#xff0c;在实现阶段未将需求的功能正确实现冗余&#xff0c;需求说明文档中未涉及的需求被实现了不满意&#xff0c;用户对产品的实现不满意也成为缺陷 缺陷等级划分 致命&#…

LeetCode刷题之HOT100之最长递增子序列

2024/7/10 晴&#xff0c;睡眠质量良好&#xff0c;到实验室时间9.18。知了在窗外聒噪&#xff0c;似乎让我安心&#xff0c;静下来。做题吧 1、题目描述 2、算法分析 给一个整数数组&#xff0c;要求出里面最长严格递增子序列的长度。遇到这种问题&#xff0c;想到的就是DP算…

基于JavaSpringBoot+Vue+uniapp微信小程序校园宿舍管理系统设计与实现(论文7000字参考+源码+LW+部署讲解)

博主介绍&#xff1a;硕士研究生&#xff0c;专注于信息化技术领域开发与管理&#xff0c;会使用java、标准c/c等开发语言&#xff0c;以及毕业项目实战✌ 从事基于java BS架构、CS架构、c/c 编程工作近16年&#xff0c;拥有近12年的管理工作经验&#xff0c;拥有较丰富的技术架…

多个单元运算符合用???:::

string a "a";string b "b";string c "c";string r a "a" ? b "b" ? c"c" ? "b" : "cc" : "33":"44";string rr a "a"? b "b" ?(c …

突破AI性能瓶颈 揭秘LLaMA-MoE模型的高效分配策略

获取本文论文原文PDF&#xff0c;请在公众号【AI论文解读】留言&#xff1a;论文解读 本文介绍了一种名为“LLaMA-MoE”的方法&#xff0c;通过将现有的大型语言模型&#xff08;LLMs&#xff09;转化为混合专家网络&#xff08;MoE&#xff09;&#xff0c;从而解决了训练MoE…

4. kvm存储虚拟化

kvm存储虚拟化 一、命令行工具管理虚拟磁盘1、查看虚拟磁盘2、添加磁盘3、删除磁盘 二、qcow2格式的磁盘文件1、创建磁盘文件2、差量镜像/快速创建虚机2.1 创建差量镜像2.2 准备配置文件2.3 创建虚拟机2.4 批量部署虚拟机 三、存储池 storage pool1、类型2、在线迁移2.1 规划后…

DNF手游攻略:云手机辅助刷副本!内置辅助工具!

DNF手游是一款备受玩家喜爱的角色扮演类游戏&#xff0c;以其独特的地下城探险和多样化的装备系统而闻名。玩家需要通过不断的挑战和升级&#xff0c;逐步增强自己的角色实力&#xff0c;最终完成各种高难度的副本任务。游戏的核心玩法包括打怪、刷装备、升级技能等。 游戏辅助…

SpringBoot源码阅读(7)——日志系统加载

SpringBoot的日志系统是在监听器中加载的。 SpringApplication的实例方法run&#xff0c;第298行。 listeners.starting(bootstrapContext, this.mainApplicationClass);最终触发了监听器LoggingApplicationListener 具体方法逻辑 private void onApplicationStartingEvent(…

LeetCode热题100刷题10:46. 全排列、78. 子集、17. 电话号码的字母组合、39. 组合总和、138. 随机链表的复制

回溯问题 46. 全排列 全排列问题&#xff1a; path 递归终止条件&#xff1a;path中是否已存储所有元素&#xff1b; for循环处理节点集合&#xff1a;used0未被使用的元素 class Solution { public:vector<int> path;vector<vector<int>> res;void backt…

【MPPT太阳能升压控制器方案】远翔升压恒流驱动芯片FP7209单节电池升压24V,30V,36V,42V,48V全系列方案,高转换效率,输出带短路保护功能

高转换效率&#xff0c;太阳能控制器方案——详解太阳能控制器PWM / MPPT极简方案其设计要点&#xff0c;升压30V&#xff0c;36V&#xff0c;42V&#xff0c;48V 使用单颗芯片FP7209即实现两级升压到30V&#xff0c;36V&#xff0c;42V&#xff0c;48V&#xff0c;相对于单极升…

RedHat运维-Ansible自动化运维基础26-管理用户与认证

1. user: 在所有受控主机上&#xff0c;新建一个用户Hello_Kitty&#xff0c;用户shell是/bin/bash&#xff0c;并将这个用户加入组wheel&#xff1b; 2. user: 在所有受控主机上&#xff0c;新建一个用户Kitty_bug&#xff0c;用户shell是/bin/bash&#xff0c;并将这个用户加…

【Python】已解决:ModuleNotFoundError: No module named ‘nltk’

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决&#xff1a;ModuleNotFoundError: No module named ‘nltk’ 一、分析问题背景 在使用Python进行自然语言处理或文本分析时&#xff0c;我们经常会用到各种库来辅助我们的工…

【转】-java多线程读写锁ReadWriteLock

Java多线程中读写锁ReadWriteLock的使用 该博客转载自​**lavimer​的​Java多线程中读写锁ReadWriteLock的使用** 1. 概念 读写锁分为读锁和写锁&#xff0c;多个读锁之间是不需要互斥的(读操作不会改变数据&#xff0c;如果上了锁&#xff0c;反而会影响效率)&#xff0c;…

【OpenCV】BGR三色通道的提取与合并--超详细解读

在OpenCV中&#xff0c;处理图像时经常需要提取或合并图像的RGB&#xff08;红、绿、蓝&#xff09;三色通道。OpenCV默认使用BGR&#xff08;蓝、绿、红&#xff09;顺序来存储图像的颜色通道&#xff0c;这一点与很多图像处理库&#xff08;如PIL/Pillow&#xff09;不同&…

Android Constant expression required (case R.id.xxx)

gradle更新到8.0后&#xff0c;遇到了这个报错 有两种解决方式&#xff1a; 1、在gradle.properties中添加下面代码 android.nonFinalResIdsfalse 2、使用if-else来判断 int id view.getId(); if (id R.id.setting_iv_back) {} else if (id R.id.setting_tv_clear) {}

大数据面试题之GreenPlum(1)

目录 介绍一下GreenPlum GreenPlum属于哪家公司的产品&#xff0c;简单说下发展历史 GreenPlum如何处理大数据 GreenPlum有哪些优势 GreenPlum的缺点有哪些 如何优化GreenPlum的性能 如何监控和分析GreenPlum的性能指标 Greenplum整体架构信息 说下Master主机与Segment…

Web知识库应用程序LibreKB

什么是 LibreKB &#xff1f; LibreKB 是一款知识库 Web 应用程序。免费、开源、自托管&#xff0c;基于 PHP/MySQL。 官方并没有 Docker 镜像&#xff0c;老苏这次图省事&#xff0c;并没有像往常一样构建一个镜像&#xff0c;而是基于 Docker 搭建了一个 LAMP 环境&#xff0…

判断一个字符串中出现次数最多的字符,统计这个次数?

1、核心算法&#xff1a;利用 charAt() 遍历这个字符串 2、把每个字符都存储给对象&#xff0c;如果对象没有该属性就为1&#xff0c;如果存了就1 3、遍历对象&#xff0c;得到最大值及出现次数和该字符 let str "aozisodsdkksdsd" let obj {} for (let i 0; i &l…

ConditionalOnJndi注解使用介绍、应用场景以及示例代码

概述 ConditionalOnJndi 是 Spring Framework 中的一个条件注解&#xff0c;用于在特定的 JNDI (Java Naming and Directory Interface) 环境条件下决定是否创建一个 bean 或配置一个 bean。JNDI 是 Java EE 规范中定义的一种用于访问命名和目录服务的 API&#xff0c;它允许 …

蹭一个围棋亚军!不要和低维的人说话——早读(逆天打工人爬取热门微信文章解读)

熬夜后需要补什么呢&#xff1f; 引言Python 代码第一篇 洞见 不要和低维的人说话&#xff08;深度好文&#xff09;第二篇 冲冲冲结尾 引言 昨晚真的是熬夜又想不出东西 真的头大 最近下围棋 这个棋感很好呀 我是K级选手 目前是8级 套几个buff 纯自学 为什么决定学围棋呢? 是…