学习目标:
目标:快速掌握 Java 入门知识
学习内容:
本文内容:使用Java实现:给定一个数组 nums 和一个值 val ,你需要原地移除所有数值等于 val 的元素,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成
实现思想:
根据题目意思,不要使用额外的数组空间也就是不能创建新数组,要求结果返回数组的新长度,既返回一个整数,那我们就可以重新使用一个数组下标(count),最后返回数组新下标即可
示例:
int nums[]={1,2,3,4,5}
val=2;
函数应该返回新的长度 4, 并且 nums 中的前四个元素为 1,3,4,5
你不需要考虑数组中超出新长度后面的元素。
实现代码
public class Practice_02 {
public static void main(String[] args) {
int[] nums={1,2,3,2,3,4};
int m= Soulution(nums,2);
System.out.println(m);
}
private static int Soulution(int[] a, int val) {
int count=0;//数组新下标
for(int i=0;i<a.length;i++){
if(a[i]==val){}
else{
a[count]=a[i];
count++;
}
}
return count;
}
}
//运行结果
4