力扣 LeetCode 27. 移除元素(Day1:数组)

解题思路:

注意:数组只能覆盖,不能删除

erase方法的复杂度为O( n )而不是O( 1 ),因为需要把删除后后面的数组向前移动

方法一:双层for循环暴力

方法二:快慢指针

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;
    }
}
相关推荐
剑挑星河月13 小时前
763.划分字母区间
数据结构·算法·leetcode
小辉同志13 小时前
74. 搜索二维矩阵
c++·leetcode·矩阵·二分查找
programhelp_14 小时前
Snowflake OA 2026 面经|3道高频真题拆解 + 速通攻略
经验分享·算法·面试·职场和发展
圣保罗的大教堂14 小时前
leetcode 3740. 三个相等元素之间的最小距离 I 简单
leetcode
Duang14 小时前
AI 真能自己写出整个 Windows 系统吗?我做了一场无监督实验
算法·设计模式·架构
少许极端14 小时前
算法奇妙屋(四十五)-CCPC备战之旅-1
java·开发语言·算法
无小道14 小时前
算法——找规律
算法·规律
圣保罗的大教堂14 小时前
leetcode 2069. 模拟行走机器人 II 中等
leetcode
地平线开发者14 小时前
目标检测的 Anchor-Free 和 NMS 到底是什么?
算法·自动驾驶
北顾笙98015 小时前
day24-数据结构力扣
数据结构·算法·leetcode