一、题目
二、解题思路
1、我的思路
我一开始的思路是创建一个ArrayList对象,然后将数组中的元素追加到ArrayList中,再通过ArrayList提供的API去解题,但是发现题目中提到了原地删除重复的元素,所以这种方法是行不通的
那就只能用传统思路了。通过循环,依次比较相邻元素是否相等,若相等,则将第二个重复元素后面的元素往前移动一位,覆盖重复的第二个元素。用一个计数器count来计算当前删除的元素数量,最后返回(数组长度 - count)。代码如下
public int removeDuplicates(int[] nums) {
int count = 0;
for (int i = 0; i < nums.length-1-count; i++) {
if(nums[i]==nums[i+1]){
for(int j=i+1;j<nums.length-count-1;j++){
nums[j] = nums[j+1];
}
count++;
i--;
}
}
return nums.length-count;
值得注意的是,再完成删除元素的操作之后,我们需要执行i--,否则在出现三个或以上重复元素的时候将无法完全删除重复的元素
我的代码时间复杂度还是比较高的,所以我们再来看下官方题解
2、官方题解
别费劲了,光盯着屏幕看是看不懂的,快去拿草稿纸演算一遍吧!
用草稿纸演算完之后,脑海里浮现一句话:这真的是碳基生物能想到的思路?!
好吧,算法路漫漫,慢慢积累吧……
int n = nums.length;
if (n == 0) {
return 0;
}
int fast = 1, slow = 1;
while (fast < n) {
if (nums[fast] != nums[fast - 1]) {
nums[slow] = nums[fast];
++slow;
}
++fast;
}
return slow;
作者:力扣官方题解
链接:https://leetcode.cn/problems/remove-duplicates-from-sorted-array/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。