删除有序数组中的重复项
给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
来源:力扣(LeetCode) 原题链接
解题思路 – 因为有0(1)的空间限制,所以不能借助其他数组 。。。。 等等 ,只能在原数组修改。 因为数组是有序的,则说明所有重复的元素都是相邻的。 首先定义两个指针,指针i负责查找第一次出现的元素,指针k负责储存元素 指针k 首先储存第一元素,另外一个指针i负责遍历数组,当发现相邻两个数组的元素不一样(nums != nums[i-1])则把i所在的元素储存在k所在的位置,然后k 向下移动一位,i继续往下遍历, 直到数组遍历完,最后k所在位置前面的所有元素就是删除有序数组重复项的结果。也是删除后数组的新长度。
代码:
public class leetCode26 {
public static int removeDuplicates(int[] nums) {
if (nums == null ) {
return 0;
}
if (nums.length == 1 ){
return 1;
}
int k = 0;
for (int i = 0; i < nums.length; i++ ) {
if (k == 0 || nums[i] != nums[i-1] ) {
nums[k] = nums[i];
k++;
}
}
return k;
}
public static void main(String[] args) {
int[] nums = {1,1,3,3,5,5,6,6,7,7};
int k = removeDuplicates(nums);
for (int i = 0; i<k; i++ ) {
System.out.print(nums[i]);
}
}
}
|