【java】实战-力扣题库:移除元素

问题描述

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。

假设 nums 中不等于 val 的元素数量为 k,要通过此题,您需要执行以下操作:

  • 更改 nums 数组,使 nums 的前 k 个元素包含不等于 val 的元素。nums 的其余元素和 nums 的大小并不重要。
  • 返回 k。

实现代码

java 复制代码
class Solution {
    public int removeElement(int[] nums, int val) {
        int size=nums.length;
        int i;
        int j;
        for(i=size-1;i>=0;i--){
            if(nums[i]==val){
                for(j=i+1;j<=size-1;j++){
                    nums[j-1] = nums[j];
                }
                size--;
            }
            
        }
        
        return size;
    }
}

或者

用双指针实现

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;
    }
}
相关推荐
狐璃同学7 分钟前
数据结构(2)线性表
数据结构·算法
啦啦啦_999912 分钟前
4. KNN算法之 特征预处理(归一化&标准化)
算法
AI是这个时代的魔法18 分钟前
Unpack Nested Data:照亮你的数据结构
数据结构·python
淘气包海鸟27 分钟前
雷达基本原理
算法·信息与通信
Tisfy29 分钟前
LeetCode 2615.等值距离和:分组(哈希表+前缀和)
算法·leetcode·散列表
啦啦啦_99991 小时前
2. KNN算法之 分类&回归API实现
算法
X journey1 小时前
机器学习进阶(23):K-means聚类
人工智能·算法·机器学习
mjhcsp1 小时前
根号快速计算牛顿迭代法
开发语言·c++·算法·迭代法
菜鸟丁小真1 小时前
LeetCode hot100-79.单词搜索
数据结构·算法·leetcode·深度优先·知识总结
WL_Aurora1 小时前
排序算法(二)
java·算法·排序算法