【算法】移除元素

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

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

    }

}
相关推荐
chao18984414 分钟前
基于C#实现Modbus通信及CRC校验
java·开发语言·c#
hxjhnct28 分钟前
JavaScript Promise 的常用API
开发语言·前端·javascript
xiaowu08039 分钟前
C# 嵌入资源加载 + 外部配置文件的兜底配置
开发语言·c#
毕设源码-邱学长40 分钟前
【开题答辩全过程】以 基于JSP论坛系统设计与实现为例,包含答辩的问题和答案
java·开发语言
FAFU_kyp1 小时前
Rust 语法速查
开发语言·后端·rust
人工智能培训1 小时前
10分钟了解向量数据库(1)
人工智能·深度学习·算法·机器学习·大模型·智能体搭建
sheji34161 小时前
【开题答辩全过程】以 基于JSP的汽车租赁管理系统为例,包含答辩的问题和答案
java·开发语言·汽车
liulilittle1 小时前
CLANG 交叉编译
linux·服务器·开发语言·前端·c++
多米Domi0111 小时前
0x3f 第21天 三更java进阶1-35 hot100普通数组
java·python·算法·leetcode·动态规划