【算法】移除元素

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

力扣题目:
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;

    }

}
相关推荐
BirdenT11 小时前
20260519紫题训练
c++·算法
Highcharts.js16 小时前
倒置百分比堆叠面积图表示列详解|Highcharts大气成分图表代码
开发语言·信息可视化·highcharts·图表开发·面积图·图表示例·推叠图
csdn_aspnet16 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
晨曦中的暮雨16 小时前
4.15腾讯 CSIG云服务产线 一面
java·开发语言
存在morning16 小时前
【GO语言开发实践】二 GO 并发快速上手
大数据·开发语言·golang
谙弆悕博士16 小时前
【附C源码】从零实现C语言堆数据结构:原理、实现与应用
c语言·数据结构·算法··数据结构与算法
xiaoerbuyu123318 小时前
开源Java 邮箱 基于SpringBoot+Vue前后端分离的电子邮件
java·开发语言
sparEE19 小时前
c++值类别、右值引用和移动语义
开发语言·c++
zhangjw3419 小时前
第11篇:Java Map集合详解,HashMap底层原理、哈希冲突、JDK1.8优化、遍历方式彻底吃透
java·开发语言·哈希算法
gaosushexiangji20 小时前
DIC系统推荐:基于千眼狼三维数字图像相关的无人机旋翼疲劳试验全场应变与位移测量
人工智能·算法