LeetCode--移除元素

题目:

解法:

双指针思想,运用快慢指针解决问题

数组中的元素是连续不间断的,因此移除元素,其实是被移除元素的下一个元素覆盖掉被移除元素,我们可以用一个快指针(fast)遍历这个数组,寻找我们新数组的值,如果原数组中的元素不等于val,则将快指针寻找到的数赋值给慢指针(slow的值对应新数组新存入元素下标),由慢指针存入新数组,直到快指针所指元素等于val,跳过该数,继续遍历。最终新数组中的元素个数其实就是slow的值(每存入一个数,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];
            }
        }
        return slow;
    }
}
相关推荐
Purple Coder6 分钟前
基于GNN的超导材料生长方法研究算法的实现-1
算法
tod1138 分钟前
C++ 核心知识点全解析(六)
c++·算法·面试经验
紫陌涵光11 分钟前
701. 二叉搜索树中的插入操作
算法·leetcode
tankeven13 分钟前
HJ100 等差数列
c++·算法
ADDDDDD_Trouvaille14 分钟前
2026.2.22——OJ98-100题
c++·算法
tankeven19 分钟前
HJ99 自守数
c++·算法
一只理智恩23 分钟前
基于 CesiumJS + React + Go 实现三维无人机编队实时巡航可视化系统
前端·人工智能·算法·golang·无人机
菜鸡儿齐30 分钟前
leetcode-分割回文串
算法·leetcode·职场和发展
重生之我是Java开发战士33 分钟前
【优选算法】链表:两数相加,两两交换节点,重排链表,合并K个升序链表,K个一组反转链表
数据结构·算法·链表
菜鸡儿齐35 分钟前
leetcode-组合总和
算法·leetcode·深度优先