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;
    }
};
相关推荐
汀、人工智能1 小时前
[特殊字符] 第21课:最长有效括号
数据结构·算法·数据库架构·图论·bfs·最长有效括号
Boop_wu1 小时前
[Java 算法] 字符串
linux·运维·服务器·数据结构·算法·leetcode
故事和你912 小时前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
Fcy6482 小时前
算法基础详解(三)前缀和与差分算法
算法·前缀和·差分
kvo7f2JTy2 小时前
基于机器学习算法的web入侵检测系统设计与实现
前端·算法·机器学习
List<String> error_P3 小时前
蓝桥杯最后几天冲刺:暴力大法(一)
算法·职场和发展·蓝桥杯
迈巴赫车主4 小时前
蓝桥杯3500阶乘求和java
java·开发语言·数据结构·职场和发展·蓝桥杯
流云鹤4 小时前
Codeforces Round 1090 (Div. 4)
c++·算法
wljy14 小时前
第十三届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(个人见解,已完结)
c语言·c++·算法·蓝桥杯·stl
高一要励志成为佬4 小时前
【数据结构】算法复杂度
数据结构