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;
    }
}

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

相关推荐
YuTaoShao8 小时前
【LeetCode 热题 100】48. 旋转图像——转置+水平翻转
java·算法·leetcode·职场和发展
百年孤独_16 小时前
LeetCode 算法题解:链表与二叉树相关问题 打打卡
算法·leetcode·链表
算法_小学生16 小时前
LeetCode 75. 颜色分类(荷兰国旗问题)
算法·leetcode·职场和发展
算法_小学生16 小时前
LeetCode 287. 寻找重复数(不修改数组 + O(1) 空间)
数据结构·算法·leetcode
岁忧16 小时前
(LeetCode 每日一题) 1865. 找出和为指定值的下标对 (哈希表)
java·c++·算法·leetcode·go·散列表
alphaTao16 小时前
LeetCode 每日一题 2025/6/30-2025/7/6
算法·leetcode·职场和发展
ゞ 正在缓冲99%…16 小时前
leetcode67.二进制求和
算法·leetcode·位运算
YuTaoShao16 小时前
【LeetCode 热题 100】240. 搜索二维矩阵 II——排除法
java·算法·leetcode
Tanecious.19 小时前
LeetCode 876. 链表的中间结点
算法·leetcode·链表
Two_brushes.1 天前
【算法】宽度优先遍历BFS
算法·leetcode·哈希算法·宽度优先