LeetCode——26. 删除排序数组中的重复项(Java)

题目介绍

题干:
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组 并在使用 O(1) 额外空间的条件下完成。

示例1:
给定数组 nums = [1,1,2], 
函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。 
你不需要考虑数组中超出新长度后面的元素。

示例2:
给定 nums = [0,0,1,1,1,2,2,3,3,4],
函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。
你不需要考虑数组中超出新长度后面的元素。

题解思路

注意题干的条件,排序的数组,而且要原地删除,返回新长度即刻

要注意数组是没有删除方法的,而且它的示例中提示,不考虑数组中的超出的元素

而且前不重复个数的下标要存储不同的元素,所以只要将不重复的元素覆盖到前面就可以

因为原地删除,限制了空间复杂度为O(1),所以要在原本的数组进行比较,所以要用双指针来实现

正确代码

public static int removeDuplicates(int[] nums) {
	// 定义返回的长度
	int i = 0;

	// 列出数组为空的情况
	if (nums.length == 0) {
	    return i;
	}

	// 定义双指针来比较数组重复的数字,不重复的话就直接将前面的覆盖住
	// 因为不考虑覆盖问题,而且是排序数组,所以最后返回i就知道几个不重复的元素个数了
	for (int j = 1; j < nums.length; j++) {
	    if (nums[i] != nums[j]) {
	        i++;
		//使最后数组前几个为不重复的元素
		nums[i] = nums[j];
		}
	}
	return i + 1;
}

总结

空间复杂度的要求达到了O(1)的要求,而且时间复杂度为O(n),代码也做到了优雅

双指针多用于指针交换,可以避免数据复制,提升系统的性能,灵活使用可以解决很多问题

虽然在Java中并没有指针的概念,但是指针的思想还是可以借用到算法题中

文章如果存在问题或者有更好的题解,希望大佬斧正和评论,希望大家和我一起进步一起优秀
posted @ 2021-02-24 16:16  21岁还不是架构师  阅读(124)  评论(0编辑  收藏  举报