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
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。