LC——删除排序数组中的重复项
题目链接:https://leetcode-cn.com/problems/remove-duplicates-from-sorted-array/solution/
要求:
给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
代码:
public int removeDuplicates(int[] nums) {
int left = 0;
int right = 1;
while (right < nums.length){
if(nums[left] < nums[right]){
int temp = nums[left+1];
nums[left+1] = nums[right];
nums[right] = temp;
left++;
}
right++;
}
return ++left;
}
思路:
双指针,比较大小,将较大的数前移。