0
点赞
收藏
分享

微信扫一扫

leetcode_26_删除有序数组中的重复项

崭新的韭菜 2022-01-16 阅读 67

题目大意

删除有序数组中的重复项
给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。

不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。

思路分析

一开始想的是两层循环分别是 i, j,如果nums[i], nums[j]不相等,那么让nums[i+1]~nums[j]的值都为nums[j]。重复上述的过程,让后面不同的值一次次覆盖前面的值。这个肯定不好,最坏能达到O(n³)。

基于上面,进行优化,上面的耗时主要集中在查找不同和覆盖。其实可以不用覆盖,声明一个辅助变量 j用来表示下一个不同元素的填装位置。遍历nums[], 如果nums[i] ≠ nums[i-1]说明 nums[i]和之前有了不同,直接令nums[++j] = nums[i] 最后将 j 返回即可

代码


class Solution{

    public static int 暴力破解(int[] nums) {
        int len = nums.length;
        int n = 1;
        for (int i = 0; i < len; i++) {
            for (int j = i + 1; j < len; j++) {
                if (nums[i] != nums[j]) {
                    for (int k = i + 1; k <= j; k++)
                        nums[k] = nums[j];
                    n++;
                    break;
                }
            }
        }
        return n;
    }
   
    public static int removeDuplicates(int[] nums) {
        int len = nums.length;
        if (len == 0 || len == 1)
            return len;
        int k = 0;
        for (int i = 1; i < len; i++) {
            if (nums[i] != nums[i - 1])
                nums[++k] = nums[i];
        }
        return k + 1;
    }
}

举报

相关推荐

0 条评论