一、问题描述
Given an array and a value, remove all instances of that value in place and return the new length.
Do not allocate extra space for another array, you must do this in place with constant memory.
The order of elements can be changed. It doesn't matter what you leave beyond the new length.
Example:
Given input array nums = [3,2,2,3]
, val = 3
Your function should return length = 2, with the first two elements of nums being 2.
二、问题分析
该题目有点类似于26题,删除数组中数值等于val的元素,并重新计算数组的长度n,并使前n个数组元素中不包含数值为val的元素。
三、代码
public class Solution {
public int removeElement(int[] nums, int val) {
if(nums==null || nums.length==0)
return 0;
int i=0;
for(int j=0;j<nums.length;j++){
if(nums[j]!=val){
nums[i]=nums[j];
i++;
}
}
return i;
}
}
Hint: