【代码随想录-Leetcode第二题:27.移除元素】

题目:

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。
不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的

样例:示例 1:

cpp 复制代码
输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2]

解释:函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。你不需要考虑数组中超出新长度后面的元素。例如,函数返回的新长度为 2 ,而 nums = 2,2,3,3 或 nums = 2,2,0,0,也会被视作正确答案。

思路

使用变量k记录等于val的个数,将后面的i元素向前移,移动k个位置,也就是i-k的位置

代码实现

cpp 复制代码
class Solution {
public:
    int removremoveElementeElement(vector<int>& nums, int val) {
    int k=0;//用来记录等于val的数组中的元素的个数
    int i=0;//遍历
    while(i<=nums.size()-1){
       if(numsnums[i]!=valval){//当元素不是val的值时执行

           nums[i-k]=nums[i];//向前移动数据,补空数据同时使得位序指向下一个元素。
            i++;
       }else{
        //如果恰好遍历到该值,就记录一次k,并且使得i++指向下一个元素。
          k++;
          i++;
       }
    }
    return nums.size()-k;//总长度减去去除重复元素后的

}
};
相关推荐
一只齐刘海的猫5 分钟前
【Leetcode】 接雨水
java·算法·leetcode
南境十里·墨染春水22 分钟前
讲讲移动语义
算法
西凉的悲伤30 分钟前
Guava类库——Range连续区间
java·算法·guava
菜菜的顾清寒31 分钟前
力扣HOT(100)54多维动态规划-最长公共子序列
算法·leetcode·动态规划
随意起个昵称35 分钟前
线性dp-LIS题目3(合唱队形)
算法
小六学编程41 分钟前
二分查找详解:从普通二分到左右边界
算法·c/c++
wayz1141 分钟前
Volume:PVO(百分比成交量震荡指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
毕竟是shy哥42 分钟前
PromptHash:基于亲和提示协同学习的自适应哈希检索跨模态算法
学习·算法·哈希算法
甄心爱学习42 分钟前
【项目实训(个人12)】
人工智能·python·算法
起个破名想半天了1 小时前
算法与数据结构之Dijkstra算法
数据结构·dijkstra·单源最短路径·迪杰斯特拉算法