快慢双指针算法--数组删除目标元素--LeetCode27

储备知识

数组,赋值操作,指针

题目

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

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

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

思路

本题我们使用同向双指针方法可以高效解决

首先我们要知道,删除的本质还是覆盖,把数组中一个数值3赋值成4,那么3就被删除了。

所以我们只需要把目标值val的下一个数值赋值给val的位置,就达到了删除val保留其他数的目的

思路如下

一开始,两个指针都站在数组的第一个位置(下标 0)。

侦察兵(快指针fast)先走,每到一个新格子,他就判断:

如果这个格子里的东西正好是我们要删掉的 val,那侦察兵就自己记住,不告诉整理员(慢指针slow),直接跳过,继续往前走。

如果格子里的东西是我们需要保留的(不等于 val),侦察兵就把这个需要保留的数直接赋值到slow的那个位置。

整理员(慢指针)听到后,就把这个好东西拿过来,放到自己当前指向的位置,然后自己往前进一步(slow++),准备接收下一个需要的数。

侦察兵一直走到数组的尽头,整理员也就把所有的需要的数都按顺序堆在了数组的前面。

最后,整理员站的位置(slow)就是删除val后数组的长度。

代码实现

cpp 复制代码
class Solution {
public:
    int removeElement(vector<int>& nums, int val) {  
        if (nums.empty()) {
            return 0;     //先判空,判断数组是否为空
        }
//定义快慢指针,这里的fast定义与后面for循环里重复,建议删除,这里这样写是为了看起来结构易懂
        int slow = 0;
        int fast =0;
//开始遍历数组
        for (int fast=0; fast < nums.size(); fast++) {
            //注意if条件
                if (nums[fast] != val) {
                nums[slow] = nums[fast];
                slow++;
            }
        }
        return slow;//题目要求的是返回数组长度,此时slow的位置就是长度
    }               //注意不是返回nums[slow]那将返回最末尾的那个数值
};

总结

双指针的方法在解决数组问题中非常好用,此题使用了快慢双指针的思想(同向双指针),重点体会和理解以下几点

1.循环每一轮是如何进行的,两个指针是如何前进的

2.if条件句里的!=

相关推荐
jc062017 小时前
6.1云原生之Docker
c++·docker·云原生
糯米团子74918 小时前
Web Worker
开发语言·前端·javascript
Mrlxl.cn18 小时前
计算机网络——网络层
c语言·数据结构·计算机网络·考研
我命由我1234518 小时前
JavaScript 开发 - 获取函数名称、获取函数参数数量、获取函数参数名称
开发语言·前端·javascript·css·html·html5·js
白晨并不是很能熬夜18 小时前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
简简单单就是我_hehe19 小时前
后端链路追踪局部采集和全量采集配置说明
java·开发语言
北京理工大学软件工程19 小时前
C#111
开发语言·c#
d111111111d19 小时前
STM32-UART封装问题解析
笔记·stm32·单片机·嵌入式硬件·学习·算法
寒秋花开曾相惜19 小时前
(学习笔记)4.2 逻辑设计和硬件控制语言HCL(4.2.1 逻辑门&4.2.2 组合电路和HCL布尔表达式)
linux·网络·数据结构·笔记·学习·fpga开发
叶子野格20 小时前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio