leetcode 数组 27.移除元素

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。

假设 nums 中不等于 val 的元素数量为 k,要通过此题,您需要执行以下操作:

更改 nums 数组,使 nums 的前 k 个元素包含不等于 val 的元素。nums 的其余元素和 nums 的大小并不重要。

返回 k。

不能直接删除,数组的元素在内存地址中是连续的,不能单独删除数组中的某个元素,只能覆盖

暴力解法,复杂度O(n2):

两层for循环,一个for循环遍历数组元素 ,第二个for循环更新数组

cpp 复制代码
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int size = nums.size();
        for (int i = 0; i < size; i++) {
            if (nums[i] == val) { // 发现需要移除的元素,就将数组集体向前移动一位
                for (int j = i + 1; j < size; j++) {
                    nums[j - 1] = nums[j];
                }
                i--; // 因为下标i以后的数值都向前移动了一位,所以i也向前移动一位
                size--; // 此时数组的大小-1
            }
        }
        return size;

    }
};

下面我一开始的代码,不规范直接超时,即便是上面的也有超时不通过风险:

class Solution {

public:

int removeElement(vector& nums, int val) {

int count=0;

for(int i=0;i<nums.size();i++){

if(nums[i]==val){

for(int j=i;j<nums.size();j++){

nums[j]=nums[++j];

i--;

count++;

}

}

}return count;

}

};

双指针法(快慢指针法): 通过一个快指针和慢指针在一个for循环下完成两个for循环的工作

快指针:寻找新数组的元素 ,新数组就是不含有目标元素的数组

慢指针:指向更新 新数组下标的位置

cpp 复制代码
快慢指针,满指针便是新数组,快指针先走判断,直接把与val不同的覆盖前面的

class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int slowIndex = 0;
        for (int fastIndex = 0; fastIndex < nums.size(); fastIndex++) {
            if (val != nums[fastIndex]) {
                nums[slowIndex++] = nums[fastIndex];
            }
        }
        return slowIndex;
    }
};

时间复杂度:O(n)

双指针法(快慢指针法)在数组和链表的操作中是非常常见的,很多考察数组、链表、字符串等操作的面试题,都使用双指针法

相关推荐
zh路西法16 分钟前
【C++并发入门】摄像头帧率计算和多线程相机读取(上):并发基础概念和代码实现
开发语言·c++·opencv
￴ㅤ￴￴ㅤ9527超级帅28 分钟前
LeetCode hot100---双指针专题(C++语言)
c++·算法·leetcode
小七蒙恩39 分钟前
go语言种的常用排序方法
算法·golang·排序算法
CXDNW1 小时前
【算法篇】回溯算法类(1)(笔记)
c++·笔记·算法·leetcode·回溯·递归
爱吃番茄炒蛋..1 小时前
【Windows】 C++实现 Socket 通讯
c++·windows
vir021 小时前
Excel 表格列序号
算法·leetcode·excel
是店小二呀2 小时前
【高阶数据结构】深度探索二叉树进阶:二叉搜索树概念及其高效实现
开发语言·数据结构·c++
van叶~2 小时前
移情别恋c++ ദ്ദി˶ー̀֊ー́ ) ——13.map&&set(模拟实现)
开发语言·数据结构·c++
玛丽亚后2 小时前
秒懂Linux之线程
linux·开发语言·jvm·c++
2401_857297912 小时前
招联金融秋招内推2025
java·前端·算法·金融·求职招聘