双指针算法
题目
给你一个 升序排列 的数组
nums
,请你** 原地** 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。
示例1:
输入:nums = [1,1,2]
输出:2, nums = [1,2,_]
解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。示例2:
输入:nums = [0,0,1,1,1,2,2,3,3,4]
输出:5, nums = [0,1,2,3,4]
解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。
解题思路
双指针
因为数组是有序的,所以重复元素必定相邻。
删除重复元素,其实就是将不重复的元素移到数组左侧,也就是将其复制到左边。
推荐使用双指针,第一个指针作快指针,遍历该数组的元素,第二个指针作慢指针,当快指针指向的元素和慢指针指向的元素不同时,将快指针指向元素复制到慢指针的后一个位置,也就是将nums[快指针]赋值给nums[慢指针+1],当快指针遍历完数组,左侧则都是不重复的元素,此时返回慢指针+1,就是新数组的长度。
以下为算法图解:
图片引用于Leetcode
代码实现:
class Solution {
public int removeDuplicates(int[] nums) {
int j = 0;
for(int i = 0; i<nums.length;i++){
if(nums[i]!=nums[j]){
nums[++j]=nums[i];
}
}
return j+1;
}
}