LeetCode力扣每日一题(Java):26、删除有序数组中的重复项
2023-12-14 09:42:46
一、题目
二、解题思路
1、我的思路
我一开始的思路是创建一个ArrayList对象,然后将数组中的元素追加到ArrayList中,再通过ArrayList提供的API去解题,但是发现题目中提到了原地删除重复的元素,所以这种方法是行不通的
那就只能用传统思路了。通过循环,依次比较相邻元素是否相等,若相等,则将第二个重复元素后面的元素往前移动一位,覆盖重复的第二个元素。用一个计数器count来计算当前删除的元素数量,最后返回(数组长度 - count)。代码如下
public int removeDuplicates(int[] nums) {
int count = 0;
for (int i = 0; i < nums.length-1-count; i++) {
if(nums[i]==nums[i+1]){
for(int j=i+1;j<nums.length-count-1;j++){
nums[j] = nums[j+1];
}
count++;
i--;
}
}
return nums.length-count;
值得注意的是,再完成删除元素的操作之后,我们需要执行i--,否则在出现三个或以上重复元素的时候将无法完全删除重复的元素
我的代码时间复杂度还是比较高的,所以我们再来看下官方题解
2、官方题解
别费劲了,光盯着屏幕看是看不懂的,快去拿草稿纸演算一遍吧!
用草稿纸演算完之后,脑海里浮现一句话:这真的是碳基生物能想到的思路?!
好吧,算法路漫漫,慢慢积累吧……
int n = nums.length;
if (n == 0) {
return 0;
}
int fast = 1, slow = 1;
while (fast < n) {
if (nums[fast] != nums[fast - 1]) {
nums[slow] = nums[fast];
++slow;
}
++fast;
}
return slow;
作者:力扣官方题解
链接:https://leetcode.cn/problems/remove-duplicates-from-sorted-array/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
文章来源:https://blog.csdn.net/lbcbjtlhmjq/article/details/134891929
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!