力扣2779. 数组的最大美丽值


首先我们应该弄清楚题意,题目给出一个数组和一个正数k,然后可以对每一个数组中的元素都进行一个操作,使得其处于(nums[i]-k,nums[i]+k),因此题意目标就是让我们找到每一个元素可以选择进行操作后,最大相同元素子序列的长度。

特别地题目上说子序列是经由原数组删除一些元素(也可能不删除)得到的一个新数组,且在此过程中剩余元素的顺序不发生改变。这和子数组是有区别的。

由这个子序列的定义,我们可以选择把数组排序,这样元素值相近的元素更容易在一起方便统计,而题目上给出的数据范围是10^5,那么只能进行一遍遍历,很明显可以对排序后的数组进行滑动窗口,只需要保证窗口的左边界的元素值+k<=窗口的右边界的元素值-k,这样在窗口中所有的元素都可以经过操作变成相同的值,我们就可以很轻松的找到最大的相同元素子序列的长度了。

完整代码如下:

cpp 复制代码
class Solution {
public:
    int maximumBeauty(vector<int>& nums, int k) {
      sort(nums.begin(),nums.end());
      // l+k>=r-k
      // r-l<=2*k
      int r=0;
      int l=0;
      int ans=0;
      int n=nums.size();
      while(r<n)
      {
        while(nums[r]-nums[l]>2*k)
        {
            l++;
        }
        ans=max(ans,r-l+1);
        r++;
      }
      
return ans;



    }
};

时间复杂度O(n)

相关推荐
cmpxr_2 分钟前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法
qiqsevenqiqiqiqi2 分钟前
前缀和差分
算法·图论
代码旅人ing11 分钟前
链表算法刷题指南
数据结构·算法·链表
Yungoal16 分钟前
常见 时间复杂度计算
c++·算法
6Hzlia23 分钟前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
不爱吃炸鸡柳1 小时前
单链表专题(完整代码版)
数据结构·算法·链表
CylMK2 小时前
题解:AT_abc382_d [ABC382D] Keep Distance
算法
Dfreedom.2 小时前
计算机视觉全景图
人工智能·算法·计算机视觉·图像算法
Morwit2 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
py有趣2 小时前
力扣热门100题之岛屿的数量(DFS/BFS经典题)
leetcode·深度优先·宽度优先