Rust 力扣 - 2653. 滑动子数组的美丽值

文章目录

题目描述

题解思路

我们遍历长度为k的的窗口

因为数据范围比较小,所以我们可以通过计数排序找到窗口中第k小的数

  • 如果小于0,则该窗口的美丽值为第k小的数
  • 如果大于等于0,则该窗口的美丽值为0

题解代码

rust 复制代码
impl Solution {
    pub fn get_subarray_beauty(nums: Vec<i32>, k: i32, x: i32) -> Vec<i32> {
        let mut cnt = [0; 101];

        let get_beauty = |cnt: &mut [i32]| -> i32 {
            let mut count = 0;
            for i in 0..101 {
                count += cnt[i];

                if count >= x {
                    if i < 50 {
                        return i as i32 - 50;
                    }

                    return 0
                }
            }

            0
        };

        for i in 0..k as usize {
            cnt[(nums[i] + 50) as usize] += 1;
        }

        let mut ans = vec![0; nums.len() - k as usize + 1];

        ans[0] = get_beauty(&mut cnt);

        for i in k as usize..nums.len() {
            cnt[(nums[i - k as usize] + 50) as usize] -= 1;
            cnt[(nums[i] + 50) as usize] += 1;

            ans[i - k as usize + 1] = get_beauty(&mut cnt);
        }

        ans
    }
}

题目链接

https://leetcode.cn/problems/sliding-subarray-beauty/

相关推荐
x***381629 分钟前
springboot和springframework版本依赖关系
java·spring boot·后端
故事不长丨34 分钟前
C#定时器与延时操作的使用
开发语言·c#·.net·线程·定时器·winform
hefaxiang37 分钟前
C语言常见概念(下)
c语言·开发语言
欧阳天风1 小时前
js实现鼠标横向滚动
开发语言·前端·javascript
java修仙传1 小时前
每日一题,力扣560. 和为 K 的子数组
算法·leetcode
yue0081 小时前
C# Directory的用法介绍
开发语言·c#
韩立学长1 小时前
基于Springboot课堂教学辅助系统08922bq1(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
ada7_2 小时前
LeetCode(python)——148.排序链表
python·算法·leetcode·链表
雨落秋垣2 小时前
手搓 Java 的用户行为跟踪系统
java·开发语言·linq
盖世英雄酱581362 小时前
java深度调试技术【第六七八章:宽字节与多字节】
java·后端