快慢双指针算法--数组删除目标元素--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条件句里的!=

相关推荐
默 语18 小时前
OpenClaw“养龙虾“热潮降温的深层解析:从技术狂欢到理性回归
android·开发语言·kotlin
平安的平安18 小时前
Python 构建AI多智能体系统:让三个 AI 协作完成复杂任务
开发语言·人工智能·python
Fcy64818 小时前
算法基础详解(4)双指针算法
开发语言·算法·双指针
zk_ken18 小时前
优化图像拼接算法思路
算法
golang学习记18 小时前
VS Code官宣:全面支持Rust!
开发语言·vscode·后端·rust
xwz小王子18 小时前
Nature Communications从结构到功能:基于Kresling折纸的多模态微型机器人设计
人工智能·算法·机器人
luj_176818 小时前
从R语言想起的,。。。
服务器·c语言·开发语言·经验分享·算法
森G18 小时前
45、QGraphicsScene 与 QGraphicsView 框架---------绘图
c++·qt
三道渊18 小时前
C语言:二级指针及void与void*的区别
c语言·开发语言
「QT(C++)开发工程师」18 小时前
C++17三大实用特性详解:折叠表达式、结构化绑定与constexpr if
jvm·c++