给你一个 非严格递增排列 的数组 nums
,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums
中唯一元素的个数。
考虑 nums
的唯一元素的数量为 k
,你需要做以下事情确保你的题解可以被通过:
- 更改数组
nums
,使nums
的前k
个元素包含唯一元素,并按照它们最初在nums
中出现的顺序排列。nums
的其余元素与nums
的大小不重要。 - 返回
k
。 -
系统会用下面的代码来测试你的题解:
int[] nums = [...]; // 输入数组 int[] expectedNums = [...]; // 长度正确的期望答案 int k = removeDuplicates(nums); // 调用 assert k == expectedNums.length; for (int i = 0; i < k; i++) { assert nums[i] == expectedNums[i]; }
如果所有断言都通过,那么您的题解将被 通过
-
转化集合法:思路:因为不重复,所以想到了set,又因为要保证顺序,所以只能用linkedhashset
class Solution {
public int removeDuplicates(int[] nums) {
Set<Integer> ls=new LinkedHashSet<>();
for(int x:nums){
ls.add(x);
}
int i=0;
for(int x:ls){
nums[i]=x;
i++;
}
return ls.size();
}
}
双指针法:思路很简单,这里解释一下为什么两个都从1开始,我一开始想从0开始但是发现fast-1=-1不行,因此就需要都换成1,其实思考一下第0索引就一个元素,不可能自己和自己重复,从1开始就可以
class Solution {
public int removeDuplicates(int[] nums) {
int slow=1;
for (int fast = 1; fast < nums.length; fast++) {
if(nums[fast]!=nums[fast-1])
nums[slow++]=nums[fast];
}
return slow;
}
}