LeetCode 26 删除有序数组中的重复项

1、通过重新定义一个新的数组,然后将其重新赋值给nums数组,输出此时的index,该方法需要额外的内存

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        int[] res = new int[nums.length];
        res[0] = nums[0];
        int index = 1;
        for( int i=1;i<nums.length;i++ ) {
            if(nums[i]!=nums[i-1]) {
                res[index] = nums[i];
                index++;
            }
        }
        for(int i=0;i<nums.length;i++) {
            nums[i] = res[i];
        }
        return index;
    }
}

2、或者是使用双指针可以节省额外的内存空间

java 复制代码
class Solution {
    public int removeDuplicates(int[] nums) {
        int slow = 0;
        for(int fast=1;fast<nums.length;fast++) {
            if(nums[fast] != nums[slow]) {
                slow++;
                nums[slow]=nums[fast];
            }
        }
        return slow+1;
    }
}

其实两个不同的指针就可以得到两个不同的数组,只是原数组无法复原,并且要在彼此不相互干扰的情况下,才能正确用双指针解答

相关推荐
共享家952710 小时前
栈相关算法题解题思路与代码实现分享
c++·leetcode
Wendy_robot10 小时前
【前缀和计算和+哈希表查找次数】Leetcode 560. 和为 K 的子数组
c++·算法·leetcode
o独酌o10 小时前
算法习题-力扣446周赛题解
算法·leetcode
云格~11 小时前
Leetcode:1. 两数之和
数据结构·算法·leetcode
xxjiaz11 小时前
水果成篮--LeetCode
java·算法·leetcode·职场和发展
肥or胖11 小时前
【LeetCode 热题 100】链表 系列
算法·leetcode·链表
Y.O.U..11 小时前
力扣HOT100——102.二叉树层序遍历
数据结构·c++·算法·leetcode
雾月5513 小时前
LeetCode 1780 判断一个数字是否可以表示成三的幂的和
java·数据结构·算法·leetcode·职场和发展·idea
Demons_kirit1 天前
Leetcode 2845 题解
算法·leetcode·职场和发展