Given an array and a value, remove all instances of that value in place and return the new length.
The order of elements can be changed. It doesn't matter what you leave beyond the new length.
ps:这个题目同样是一个双指针的问题,比较简单,代码如下所示
1 class Solution { 2 public: 3 int removeElement(vector<int>& nums, int val) { 4 int pos = 0; 5 int sz = nums.size(); 6 for (int i = 0; i < sz; ++i){ 7 if (nums[i] != val){ 8 nums[pos++] = nums[i]; 9 } 10 } 11 return pos; 12 } 13 };
java版本:
1 public class Solution { 2 public int removeElement(int[] nums, int val) { 3 int pos = 0; 4 for(int i = 0; i < nums.length; ++i){ 5 if(nums[i] != val) 6 nums[pos++] = nums[i]; 7 } 8 return pos; 9 } 10 }