初级算法之删除数组中的重复项
题目
给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
解法:使用双指针
代码如下
Class soluion{
public int removeDuplicates(int[] nums)
int back=0; //对应的back指针,一开始指向第一个元素
int front=1; //对应front指针,一开始指向第二个元素
if(nums==null){ //当数组不存在时,直接结束
return 0;
}
for(;front<nums.length;front++){//从front开始遍历数组,无论怎么样,front都会+1
if(nums[back]!=nums[front]){//当两数不同时
back++;//back指针前进一位
nums[back]=nums[front];//front指针对应的值赋值给back指针对应的值
}
return back+1;//返回数组的长度,游戏结束!!
}
}