博客
关于我
27.移除元素
阅读量:646 次
发布时间:2019-03-15

本文共 799 字,大约阅读时间需要 2 分钟。

为了解决这个问题,我们需要在原地移除数组中所有等于给定值的元素,并返回移除后数组的新长度。我们不能使用额外的数组空间,因此必须在原数组上进行操作。

方法思路

我们可以使用双指针法来解决这个问题。快指针遍历数组,遇到不等于目标值的元素时,将其复制到慢指针当前的位置,并前进慢指针。这种方法确保我们在原地修改数组,同时不使用额外的空间,时间复杂度为 O(n),空间复杂度为 O(1)。

解决代码

public class Test {    public int removeElement(int[] nums, int val) {        int i = 0;        for (int j = 0; j < nums.length; j++) {            if (nums[j] != val) {                nums[i] = nums[j];                i++;            }        }        return i;    }    public static void main(String[] args) {        int[] nums = {0,1,2,2,3,0,4,2};        System.out.println(new Test().removeElement(nums, 2));    }}

代码解释

  • 初始化指针:慢指针 i 初始化为 0,用于记录新数组的起始位置。
  • 遍历数组:快指针 j 从 0 开始遍历数组。
  • 检查元素:如果当前元素 nums[j] 不等于目标值 val,则将其复制到 nums[i],然后前进慢指针 i
  • 返回结果:遍历结束后,慢指针 i 的值即为新数组的长度。
  • 这种方法确保我们在原地修改数组,符合题目要求,同时保证了时间和空间上的效率。

    转载地址:http://fxelz.baihongyu.com/

    你可能感兴趣的文章
    Netty工作笔记0045---Netty模型梳理
    查看>>
    Netty工作笔记0045---异步模型原理剖析
    查看>>
    Netty工作笔记0046---TaskQueue自定义任务
    查看>>
    Netty工作笔记0046---异步模型原理剖析
    查看>>
    Netty工作笔记0047---Http服务程序实例
    查看>>
    Netty工作笔记0048---Http服务过滤资源
    查看>>
    Netty工作笔记0049---阶段内容梳理
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0051---Netty核心模块2
    查看>>
    Netty工作笔记0052---Pipeline组件剖析
    查看>>
    Netty工作笔记0053---Netty核心模块梳理
    查看>>
    Netty工作笔记0054---EventLoop组件
    查看>>
    Netty工作笔记0055---Unpooled应用实例1
    查看>>
    Netty工作笔记0056---Unpooled应用实例2
    查看>>
    Netty工作笔记0057---Netty群聊系统服务端
    查看>>
    Netty工作笔记0058---Netty群聊系统客户端
    查看>>
    Netty工作笔记0059---Netty私聊实现思路
    查看>>
    Netty工作笔记0060---Netty心跳机制实例
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0061---Netty心跳处理器编写
    查看>>