Leetcode27 —— 移除元素(双指针)

目录

题目:

题解:

C++代码:

题目:

​​​​​​

题解:

  • 快指针 right:遍历数组,筛选出不等于 val 的 "有效元素"

  • 慢指针 left:指向新数组下一个填充位置,接收快指针找到的有效元素。

  • 执行逻辑:快指针遍历过程中,遇到有效元素就赋值给慢指针位置,慢指针右移;遍历结束后,慢指针的位置即为新数组长度。

一些初学者的思路:

假设你不用双指针,可能会有两种思路,但都有明显问题:

  • 思路 1:创建新数组 遍历原数组,把不等于val的元素放进新数组,最后返回新数组长度。 问题:题目要求「原地修改」(不能额外开数组),违反题意,且空间复杂度变成 O (n)(浪费内存)。

  • 思路 2:遇到 val 就删除(数组删除) 遍历数组,每找到一个val就用erase删除。问题:数组删除元素会导致后续元素全部前移,比如删除第 0 位的 3,[3,2,2,3]→[2,2,3],遍历指针容易漏检;且删除操作的时间复杂度是 O (n),整体时间复杂度变成 O (n²)(效率低)。

C++代码:

复制代码
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int n = nums.size();
        int l = 0;
        for(int r = 0; r < n; r++){
            if(nums[r]!=val){
                nums[l] = nums[r];
                l++;
            }
        }
        return l;
    }
};
相关推荐
卷福同学3 小时前
QClaw内测体验,能用微信指挥AI干活了
人工智能·算法·ai编程
sali-tec3 小时前
C# 基于OpenCv的视觉工作流-章34-投影向量
图像处理·人工智能·opencv·算法·计算机视觉
xiaoye-duck3 小时前
《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂
数据结构·c++·算法·递归
Eward-an4 小时前
【算法竞赛/大厂面试】盛最多水容器的最大面积解析
python·算法·leetcode·面试·职场和发展
山栀shanzhi4 小时前
归并排序(Merge Sort)原理与实现
数据结构·c++·算法·排序算法
阿豪学编程4 小时前
LeetCode438: 字符串中所有字母异位词
算法·leetcode
Trouvaille ~4 小时前
【递归、搜索与回溯】专题(七):FloodFill 算法——勇往直前的洪水灌溉
c++·算法·leetcode·青少年编程·面试·蓝桥杯·递归搜索回溯
地平线开发者4 小时前
征程 6P codec decoder sample
算法·自动驾驶
地平线开发者4 小时前
征程 6X Camera 接入数据评估
算法·自动驾驶
Storynone4 小时前
【Day23】LeetCode:455. 分发饼干,376. 摆动序列,53. 最大子序和
python·算法·leetcode