题目大意
删除有序数组中的重复项
给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
思路分析
一开始想的是两层循环分别是 i, j,如果nums[i], nums[j]
不相等,那么让nums[i+1]~nums[j]
的值都为nums[j]。重复上述的过程,让后面不同的值一次次覆盖前面的值。这个肯定不好,最坏能达到O(n³)。
基于上面,进行优化,上面的耗时主要集中在查找不同和覆盖。其实可以不用覆盖,声明一个辅助变量 j
用来表示下一个不同元素的填装位置。遍历nums[], 如果nums[i] ≠ nums[i-1]
说明 nums[i]
和之前有了不同,直接令nums[++j] = nums[i]
最后将 j 返回即可
代码
class Solution{
public static int 暴力破解(int[] nums) {
int len = nums.length;
int n = 1;
for (int i = 0; i < len; i++) {
for (int j = i + 1; j < len; j++) {
if (nums[i] != nums[j]) {
for (int k = i + 1; k <= j; k++)
nums[k] = nums[j];
n++;
break;
}
}
}
return n;
}
public static int removeDuplicates(int[] nums) {
int len = nums.length;
if (len == 0 || len == 1)
return len;
int k = 0;
for (int i = 1; i < len; i++) {
if (nums[i] != nums[i - 1])
nums[++k] = nums[i];
}
return k + 1;
}
}