Leetcode3634.排序+双指针法

Problem: 3634. 使数组平衡的最少移除数目

思路

排序+双指针法

解题过程

left指向元素x,right右移,注意边界条件

复杂度

  • 时间复杂度: O(nlogN)
  • 空间复杂度: O(logN)

代码

cpp 复制代码
class Solution {
public:
    int minRemoval(vector<int>& nums, int k) {
        int n=nums.size();
        sort(nums.begin(),nums.end());//对数组nums排序
        int ans=n,right=0;//定义并初始化最小移除数目ans和右指针right
        for(int left=0;left<n;++left){//左指针left遍历整个数组
            while(right<n&&nums[right]<=static_cast<long long>(nums[left])*k){
                ++right;
            }//而右指针right不断向右移动,直到指向第一个严格大于nums[left]的元素,或者超出数组边界为止。
            ans=min(ans,n-(right-left));//更新ans的值
        }
        return ans;
    }
};
相关推荐
NiceCloud喜云20 分钟前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
小羊在睡觉33 分钟前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
cjhbachelor44 分钟前
c++继承
c++
3DVisionary1 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
好评笔记1 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466851 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
肩上风骋1 小时前
C++14特性
开发语言·c++·c++14特性
_日拱一卒1 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM2 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro3 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言