LeetCode:6390. 滑动子数组的美丽值

news/2024/4/24 10:59:24/文章来源:https://blog.csdn.net/weixin_42204569/article/details/130350769
🍎道阻且长,行则将至。🍓

🌻算法,不如说它是一种思考方式🍀


算法专栏: 👉🏻123


一、🌱6390. 滑动子数组的美丽值

  • 题目描述:给你一个长度为 n 的整数数组 nums ,请你求出每个长度为 k 的子数组的 美丽值 。
    一个子数组的 美丽值 定义为:如果子数组中第 x 小整数 是 负数 ,那么美丽值为第 x 小的数,否则美丽值为 0 。
    请你返回一个包含 n - k + 1 个整数的数组,依次 表示数组中从第一个下标开始,每个长度为 k 的子数组的 美丽值 。
    子数组指的是数组中一段连续 非空 的元素序列。

  • 来源:力扣(LeetCode)

  • 难度:中等

  • 提示:
    n == nums.length
    1 <= n <= 105
    1 <= k <= n
    1 <= x <= k
    -50 <= nums[i] <= 50

  • 示例 1
    输入:nums = [1,-1,-3,-2,3], k = 3, x = 2
    输出:[-1,-2,-2]
    解释:总共有 3 个 k = 3 的子数组。
    第一个子数组是 [1, -1, -3] ,第二小的数是负数 -1 。
    第二个子数组是 [-1, -3, -2] ,第二小的数是负数 -2 。
    第三个子数组是 [-3, -2, 3] ,第二小的数是负数 -2 。
    示例 2
    输入:nums = [-1,-2,-3,-4,-5], k = 2, x = 2
    输出:[-1,-2,-3,-4]
    解释:总共有 4 个 k = 2 的子数组。
    [-1, -2] 中第二小的数是负数 -1 。
    [-2, -3] 中第二小的数是负数 -2 。
    [-3, -4] 中第二小的数是负数 -3 。
    [-4, -5] 中第二小的数是负数 -4 。
    示例 3
    输入:nums = [-3,1,2,-3,0,-3], k = 2, x = 1
    输出:[-3,0,-3,-3,-3]
    解释:总共有 5 个 k = 2 的子数组。
    [-3, 1] 中最小的数是负数 -3 。
    [1, 2] 中最小的数不是负数,所以美丽值为 0 。
    [2, -3] 中最小的数是负数 -3 。
    [-3, 0] 中最小的数是负数 -3 。
    [0, -3] 中最小的数是负数 -3 。

🌴解题

1.暴力排序(超时)

就是遍历的时刻,把这 k 个数的字数组排序一下,选取第 x 小作为结果保存。

class Solution {public int[] getSubarrayBeauty(int[] nums, int k, int x) {int length = nums.length;int[] ans=new int[length-k+1];for (int i = 0; i < length-k+1; i++) {int num=findx(nums,i,k,x);if(num<0)ans[i]=num;else ans[i]=0;}return ans;}private static int findx(int[] nums, int i, int k, int x) {int[] tems=new int[k];for (int j = 0; j < k; j++) {tems[j]=nums[i];i++;}Arrays.sort(tems);return tems[x-1];}
}

肯定是超过时间限制了!
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.自排序的 Map

我们知道在 Map 集合是一种键值对的结构,我们可以使用 key 来存储数组元素,使用 value 来存储元素在子串出现的次数。其中的 TreeMap 是一种自动排序的数据结构,所以可以有这种做法:

class Solution {public int[] getSubarrayBeauty(int[] nums, int k, int x) {int[] result = new int[nums.length - k + 1];//存放返回结果Map<Integer,Integer> nmap=new TreeMap<>();// key 数字 : value 个数for (int i = 0; i < nums.length; i++) { //遍历每一个数字if(!nmap.containsKey(nums[i])){//集合中不包含这个数字nmap.put(nums[i], 1);}else{nmap.put(nums[i], nmap.get(nums[i])+1);//集合中包含这个数字,对其 value + 1}if(i >= k-1){int j=0;for (int key: nmap.keySet()) {j+=nmap.get(key);if(j >= x) {result[i - k + 1] = key < 0 ? key : 0;break;}}if(nmap.get(nums[i - k + 1])==1){//集合中包含 1 个这个数字nmap.remove(nums[i - k + 1]);}else{nmap.put(nums[i - k + 1], nmap.get(nums[i - k + 1]) - 1);//集合中包含多个这个数字,对其 value - 1}}}return result;}
}

在这里插入图片描述

3.数组 hash

题目说明了 -50 <= nums[i] <= 50,因此只需要创建大小为 101 的数组 count 即可,数组 count 的索引表示原数组的值,数组 count 的表示出现的次数。

class Solution {public int[] getSubarrayBeauty(int[] nums, int k, int x) {int[] result = new int[nums.length - k + 1];//存放返回结果Map<Integer,Integer> nmap=new TreeMap<>();// key 数字 : value 个数for (int i = 0; i < nums.length; i++) { //遍历每一个数字if(!nmap.containsKey(nums[i])){//集合中不包含这个数字nmap.put(nums[i], 1);}else{nmap.put(nums[i], nmap.get(nums[i])+1);//集合中包含这个数字,对其 value + 1}if(i >= k-1){int j=0;for (int key: nmap.keySet()) {j+=nmap.get(key);if(j >= x) {result[i - k + 1] = key < 0 ? key : 0;break;}}if(nmap.get(nums[i - k + 1])==1){//集合中包含 1 个这个数字nmap.remove(nums[i - k + 1]);}else{nmap.put(nums[i - k + 1], nmap.get(nums[i - k + 1]) - 1);//集合中包含多个这个数字,对其 value - 1}}}return result;}
}

在这里插入图片描述


🌵孤山寺北贾亭西,水面初平云脚低。 — 白居易

返回第一页。☝


☕物有本末,事有终始,知所先后。🍭

🍎☝☝☝☝☝我的CSDN☝☝☝☝☝☝🍓

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

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

相关文章

波形生成:均匀和非均匀时间向量

波形生成—— 脉冲、chirp、VCO、正弦函数、周期性/非周期性和调制信号 使用 chirp 生成线性、二次和对数 chirp。使用 square、rectpuls 和 sawtooth 创建方波、矩形波和三角形波。 如需了解此处未显示的其他无线波形生成功能&#xff0c;请参阅无线波形发生器 (Communicat…

完整的生产车间管理流程是怎样的?六大步骤分享

阅读本文您将了解&#xff1a;1.生产车间管理的特征&#xff1b;2.生产车间管理流程具体步骤&#xff1b;3.生产车间管理流程规范的重要性。 一、生产车间管理的特征 车间管理是指对车间所从事的各项生产经营活动进行计划、组织、指挥、协调和控制的一系列管理工作。生产车间…

巧用千寻位置GNSS软件| 电力线勘测如何实现?

正如大家所知&#xff0c;电力线勘测是在做电力线路设计之前对设计线路沿途自然环境进行勘察测量&#xff0c;最后把手簿测量数据在电脑端经过转换输出为电力软件专用格式数据的专用功能。 那么在千寻位置GNSS软件中该如何操作完成电力线的勘察测量呢&#xff1f; 点击【测量】…

SwiftUI 中 TabView 如何原生使用类 UIPageView 的翻页样式?

功能需求 我们知道 TabView 是 SwiftUI 中非常好用的布局组织容器,它可以分类组织视图并依次展示给用户。 从 SwiftUI 2.0 开始(iOS 14.0+),TabView 除了常规的以标签(Tab Label)样式显示外,还可以用类似 UIPageView 的样式分页原生显示视图,显得更加简洁: 如上图所…

AWT-对话框——Dialog以及其子类FileDialog

Dialog: Dialog时Window类的子类&#xff0c;时一个容器类&#xff0c;属于特殊组件。对话框是可以独立存在的顶级窗口&#xff0c;因此用法与普通窗口的用法几乎完全一样&#xff0c;但是使用对话框需要注意以下几点&#xff1a; 对话框通常依赖于其它窗口&#xff0c;就是通…

基于Java+SpringBoot+vue学生学习平台详细设计实现

基于JavaSpringBootvue学生学习平台详细设计实现 博主介绍&#xff1a;5年java开发经验&#xff0c;专注Java开发、定制、远程、指导等,csdn特邀作者、专注于Java技术领域 作者主页 超级帅帅吴 Java项目精品实战案例《500套》 欢迎点赞 收藏 ⭐留言 文末获取源码联系方式 文章目…

AI Stable Diffusion Prompt参数【二】之 生成效果查验

AI Stable Diffusion Prompt参数【二】之 生成效果查验 效果国漫风生成参数配置prompt&#xff1a;Negative prompt:Model:Steps:Sampler:CFG scale:Clip skip:Model hash:Hires upscale:Hires upscaler:Denoising strength: 全部效果 效果 国漫风生成参数配置 prompt&#xf…

拉格朗日粒子扩散模式FLEXPART

为了高效、精准地治理区域大气污染&#xff0c;需要弄清污染物的来源。拉格朗日粒子扩散模式FLEXPART通过计算点、线、面或体积源释放的大量粒子的轨迹&#xff0c;来描述示踪物在大气中长距离、中尺度的传输、扩散、干湿沉降和辐射衰减等过程。该模式既可以通过时间的前向运算…

汇编与内联 x86-64

机器字长 x86是32位系统 64是64位系统 这里的32和64&#xff0c;指的都是机器字长 机器字长是 能直接进行整数/位运算的大小指针的大小(索引内存的范围) 容易与机器字长混淆的概念&#xff1a;字 字 字存储字长 字是MDR寄存器的位数&#xff0c;代表每个主存存储体中的存储…

[HDU - 4578]Transformation(线段树+多重懒标记)

[HDU - 4578]Transformation&#xff08;线段树多重懒标记&#xff09; 一、问题二、分析1、节点定义2、pushup3、pushdown&#xff08;1&#xff09;每种标记如何下传&#xff1f;赋值乘法加法 &#xff08;2&#xff09;三种标记下传的优先级问题 三、代码 一、问题 二、分析…

C++数据结构:手撕AVL树

目录 一. 什么是AVL树 二. AVL树的节点定义 三. AVL树的插入操作 3.1 寻找插入位置 3.2 更新平衡因子 3.3 AVL树的旋转调整 3.4 AVL树插入操作的整体实现 四. AVL树的检验 附录&#xff1a;AVL树的实现完整代码 AVL树定义代码 -- AVLTree.h AVL树检验代码 -- test.…

MFC加载动态gif图片文件C++语言,基于MFC的动画播放控件

MFC加载动态gif图片&#xff0c;使用VS2015环境 一、将下载的PictureEx.h和PictureEx.cpp放在工程文件的目录下&#xff0c;动态gif图片放在工程文件的res文件夹下&#xff1b;&#xff08;GIF动图下载 https://icons8.com/preloaders/en/search/move&#xff09; &#xff08…

软考软件设计师 操作系统笔记

操作系统地位 程序顺序执行&#xff08;进程管理&#xff09; 程序顺序执行的特征&#xff0c;顺序性封闭性可再现性 前趋图 P1结束后 V操作 SS1 P2操作前先执行S S -1 此时S0 一个箭头对应一个信号量 程序并发执行和前驱图 找到输入i计算c输出p&#xff0c;如果找不到就…

“老司机”机器视觉工程师警告,硬件,软件,固件,程序使用新版本务必谨慎

做任何事情之前&#xff0c;程序先保存。没保存&#xff0c;真的会哭的。千万别保存在系统盘。​ 机器视觉最终的目的解决是什么问题&#xff1f;项目验收结束。 如果公司不知道或者希望去测试新的东西&#xff0c;要积极主动去使用&#xff0c;也会学到很多新的东西&#xff…

Java版本企业电子招投标采购系统源代码——功能模块功能描述+数字化采购管理 采购招投标

​ 功能模块&#xff1a; 待办消息&#xff0c;招标公告&#xff0c;中标公告&#xff0c;信息发布 描述&#xff1a; 全过程数字化采购管理&#xff0c;打造从供应商管理到采购招投标、采购合同、采购执行的全过程数字化管理。通供应商门户具备内外协同的能力&#xff0c;为外…

塔望食研院丨百年益生菌,千亿市场正蓝海!

2022年12月塔望咨询开设塔望食品大健康消费研究院&#xff08;简称塔望食研院&#xff09;栏目&#xff0c;塔望食研院以“为食品行业品牌高质量发展赋能”为理念&#xff0c;将不定期发布食品大健康行业研究、消费研究报告。塔望食研院致力于结合外部数据、消费调研数据、企业…

Mybatis学习基础篇(一)——使用Maven快速搭建一个mybatis项目,并实现简单的增删改查

题外话&#xff1a; 在了解mybatis框架之前&#xff0c;我先说明一句&#xff0c;目前主流的框架技术层出不穷&#xff0c;每个人都有自己喜欢的技术框架&#xff0c;自己喜欢用就行。技术并没有高低之分&#xff0c;喜欢用就用&#xff0c;虽然目前大部分人都喜欢向新技术看齐…

C++、STL标准模板库和泛型编程 ——迭代器、 算法、仿函数(侯捷)

C、STL标准模板库和泛型编程 ——迭代器、 算法、仿函数 &#xff08;侯捷&#xff09; 迭代器iterator_category 算法accumulatefor_eachreplacecountfindsortbinary_search 仿函数 functors(六大部件中最简单的一种&#xff01;) 使用一个东西&#xff0c;却不明白它的道理&a…

4月21日第壹简报,星期五,农历三月初二

4月21日第壹简报&#xff0c;星期五&#xff0c;农历三月初二坚持阅读&#xff0c;静待花开1. 推特拒向大模型免费开放数据&#xff01;马斯克威胁起诉微软&#xff1b;Reddit宣布不再向大模型免费开放数据&#xff0c;要求科技巨头付费使用API接口。2. 浙江&#xff1a;鼓励杭…

2023.04.24 c++第六讲

作业&#xff1a; 1. 手动实现顺序栈&#xff0c;要求实现数据结构中&#xff0c;所有栈的相关操作 #include <iostream> #define MAXSIZE 20 //宏定义&#xff0c;栈的最大容量 using namespace std;template <typename T> class stacklink { pri…