【代码随想录】LC 27. 移除元素

文章目录

前言

本专栏文章为《代码随想录》书籍的刷题题解以及读书笔记,如有侵权,立即删除。

一、题目

1、原题链接

27. 移除元素

2、题目描述



二、解题报告

1、思路分析

  1. 暴力解法
    利用两层循环 ,第一层循环找到值等于val的元素,第二层循环"移除元素"。(数组移除元素就是将该位置后面的元素依次向前移动一个位置 ,从而达到"移除"的效果,注意移动的顺序:应该从待移动序列前往后依次向前移动,否则会造成数组元素值"丢失")
  2. 双指针法
    设置两个指针,快指针用来遍历数组慢指针用来找到值为val的元素 。具体流程:快指针和慢指针初始指向数组中第一个元素,然后快指针向后遍历数组,当数组元素的值不等于val时,慢指针也向后移动,同时记录该元素在数组中如果数组元素的值等于val时,慢指针不动,快指针继续向后遍历,直到数组元素的值不等于val ,执行前述操作。直至快指针遍历完整个数组。算法结束,此时慢指针正好记录了移除重复元素后的数组长度

2、时间复杂度

暴力解法时间复杂度O(n^2)

双指针法时间复杂度O(n)

3、代码详解

暴力解法代码

cpp 复制代码
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int cnt = nums.size(); 
        //注意循环条件i<cnt,不要写成i<nums.size()造成错误   
        for (int i = 0; i < cnt; i++) {
            if (nums[i] == val) {
                //"移除"过程:i位置后的所有元素向前移动一个位置
                for (int j = i + 1; j < cnt; j++) {
                    nums[j-1] = nums[j];
                }
                cnt--;
                //i后面元素都向前移动了一个位置,i也向前移动一个位置
                //下一次循环时相当于i没有动,而元素向前移动了一个位置
                //i也就指向了下一个需要遍历的数组元素
                i--;
            }
        }
        return cnt;
    }
};

双指针法代码

cpp 复制代码
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {
        int slowPoint=0;
        //快指针遍历数组
        for (int fastPoint = 0; fastPoint < nums.size(); fastPoint++) {
            //慢指针记录结果:只记录值不为val的所有元素
            if (nums[fastPoint] != val) {
                nums[slowPoint++]=nums[fastPoint];
            }
        }
        //此时slowPoint正好记录了移除重复元素后的数组元素个数
        return slowPoint;
    }
};

三、知识风暴

  • 双指针法
相关推荐
列星随旋27 分钟前
线段树和树状数组的学习
学习·算法
楼田莉子1 小时前
C++17新特性:__had_include/属性/求值顺序规则
开发语言·c++·后端
全糖可乐气泡水2 小时前
Codex适配国产信创环境安装部署与技术适配全解析
开发语言·git·python·算法·百度
h_a_o777oah3 小时前
状态机+划分型 DP :深度解析K-划分问题下 DP 状态的转移逻辑(洛谷P2679 P2331 附C++代码)
c++·算法·动态规划·acm·状态机dp·划分型dp·滚动数组优化
05候补工程师3 小时前
从算法理想向工程现实的跨越:SLAM 核心架构、思维误区与 Nav2 实战避坑指南
人工智能·算法·安全·架构·机器人
手写码匠4 小时前
Android 17 适配实战指南:新特性解读、隐私变更与迁移全攻略
人工智能·深度学习·算法·aigc
雪度娃娃4 小时前
Asio异步读写——连接的安全回收问题
开发语言·c++·安全·php
珊瑚里的鱼4 小时前
leetcode42雨水
算法·leetcode
不吃土豆的马铃薯4 小时前
Spdlog 进阶:日志基本控制、日志格式控制、异步记录器
linux·服务器·开发语言·前端·c++
水木流年追梦5 小时前
大模型入门-大模型的推理策略
开发语言·python·算法·正则表达式·prompt