本文主要是介绍leetcode26.删除有序数组中的重复项,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
leetcode26.删除有序数组中的重复项
/**
* 给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,
* 返回删除后数组的新长度。
* <p>
* 不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
*/
- 题目要求原地删除重复的元素,使每个元素只出现一次,因此不能创建新数组,可以考虑将不重复的元素继续存储到这个数组中
- 因为数组在底层是连续存储的,及地址是连续的,这样的结构使得在原数组中存储新数据成为可能
- 只是在存储新数据后原数组的元素发生改变,
- 要保证新数组元素的唯一,立刻想到的就是Hash结构,能够保证元素的不可重复性
public int removeDuplicates(int[] nums) {
//创建HashSet集合,由于Hash的元素不重复性,可以保证拿到的元素唯一
HashSet<Integer> set = new HashSet<>();
//记录不重复的元素数目
int count = 0;
for (int i = 0; i < nums.length; i++) {
//遍历数组,将不重复的元素继续存储到这个数组中,
int num = nums[i];
//如果添加成功则返回true
if (set.add(num)) {
nums[count] = num;
count++;
}
}
return count;
}
这篇关于leetcode26.删除有序数组中的重复项的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!