【算法】移除元素

今天讲的是力扣题目的题解:

力扣题目:
72.移除元素

题目描述:

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

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

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

核心思路:

使用快慢指针的思路,fast指向的是有效元素,slow指向的是新数组的下标

第一步:

定义一个慢指针:slow 指向的是新数组的下标

第二步:

定义一个快指针:fast 的目的是遍历数组的每一个元素,将不是val的有效元素赋值给slow的位置

第三步:

利用for循环,通过fast++来遍历整个数组

第四步:

当在循环的过程中,遇到不是val的有效元素,就将这个有效元素通过nums[fast] 来记录,进一步将这个有效元素赋值给slow的位置,让slow++,因为slow代表的在新数组中有效元素存放的位置

代码如下:

java 复制代码
int slow  = 0;

第一步:

定义一个慢指针:slow 指向的是新数组的下标

第二步:

定义一个快指针:fast 的目的是遍历数组的每一个元素,将不是val的有效元素赋值给slow的位置

java 复制代码
for(int fast = 0; fast < nums.length; fast++)

第三步:

利用for循环,通过fast++来遍历整个数组

第四步:

当在循环的过程中,遇到不是val的有效元素,就将这个有效元素通过nums[fast] 来记录,进一步将这个有效元素赋值给slow的位置,让slow++,因为slow代表的在新数组中有效元素存放的位置

java 复制代码
 if(nums[fast] != val){
    nums[slow] = nums[fast];
    slow++;
   }

完整代码如下所示:

java 复制代码
class Solution {

    public int removeElement(int[] nums, int val) {

        int slow  = 0;

        for(int fast = 0; fast < nums.length; fast++){

            if(nums[fast] != val){

                nums[slow] = nums[fast];

                slow++;

            }

        }

        return slow;

    }

}
相关推荐
VB.Net20 小时前
VB.Net循序渐进(第二版)
开发语言·.net·vb.net
埃伊蟹黄面20 小时前
深入理解STL关联容器:map/multimap与set/multiset全解析
开发语言·c++
21号 120 小时前
4.客户端(Redis)
开发语言·数据库·github
Python算法实战20 小时前
平安大模型面试题:Self-Attention 原理与多头注意力设计
人工智能·算法·自然语言处理·大模型·面试题
Python算法实战20 小时前
腾讯送命题:手写多头注意力机制。。。
人工智能·算法·面试·大模型·强化学习
青牛科技-Allen20 小时前
7个常见的DFM问题及其对PCB制造的影响
开发语言·单片机·制造·usb麦克风·立体声录音笔
「QT(C++)开发工程师」20 小时前
C++语言编程规范-风格
linux·开发语言·c++·qt
hello kitty w20 小时前
Python学习(10) ----- Python的继承
开发语言·python·学习
前端小刘哥20 小时前
现场直播的技术革新者:视频直播点播平台EasyDSS在现场直播场景中的技术应用
算法
草莓工作室20 小时前
数据结构9:队列
c语言·数据结构·队列