LeetCode27移除元素的两种方法(Java实现)

LeetCode27移除元素的两种方法

首先,我们来看下题目。

在这里首先补充下数组的知识,我们知道数组中的元素是无法进行删除 的,只能覆盖,我们看到的删除操作实际上是底层进行了覆盖。

那么我们再来看这道题,题目要求找到目标的元素进行删除,那么其实就是让我们将目标元素进行一个覆盖 操作。
方法1:暴力求解

暴力求解的思路如下,首先我们用一个指针flag指向数组下标为0的地方,flag用于遍历整个数组,如果找到了目标值,那么用另一个指针

Key

进行覆盖操作,也就是将所有的元素向前移一位。大概思想就是这样。具体的代码实现如下:

java 复制代码
public static int removeElement(int[] nums, int val) {
    int i=0; //指针用于遍历数组
    int j =0;//用于进行覆盖操作
    int len=nums.length;
    for (i=0;i<len;i++){
        if (nums[i]==val){
            for (j=i+1;j<len;j++){//这里让j=i+1主要是因为防止越界。
                nums[j-1]=nums[j];

            }
            //每进行一次覆盖,数组长度减1,并且让i--,
            //因为可能覆盖之后的元素为目标值。
            len--;
            i--;

        }
    }

    return len;
}

方法1:双指针解法

双指针的思路如下,首先定义一个快指针fast ,定义一个慢指针slow ,快指针用于遍历数组,慢指针用于进行覆盖操作,这里我们举个例子

如图所示,我们将快指针指向第一个元素,同样慢指针指向第一个元素,这时fast 开始遍历,假如我们的targe值为3,遍历到第一个元素发现不是targe值,此时将数组nums[fast]的元素赋值给nums[slow] ,然后slow++ ,进行下一元素的查找。这样遍历到最后,数组就变为[1,2,5],此时slow 指向下标为3的地方,直接对slow进行返回即可。具体的代码实现如下:

java 复制代码
    public static int removeElement(int[] nums, int val) {

        int len =nums.length;
        int slow=0;
        int fast=0;
        for (fast=0;fast<len;fast++){
            if (nums[fast]!=val){
                nums[slow]=nums[fast];
                slow++;
            }
        }
        return slow;


}

今天的例题思路和代码讲解到这里就结束了,如果哪里看不懂可以在文章下方留言,博主看到了会进行答疑,觉得博主写的不错的麻烦给个小小的3连吧,谢谢(●ˇ∀ˇ●)!

相关推荐
寻星探路4 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
你撅嘴真丑6 小时前
第九章-数字三角形
算法
曹牧6 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
uesowys6 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder6 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮6 小时前
AI 视觉连载1:像素
算法
爬山算法7 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
智驱力人工智能7 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
kfyty7257 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎7 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven