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

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

相关推荐
Keying,,,,6 小时前
力扣hot100 | 图论 | 200. 岛屿数量、994. 腐烂的橘子、207. 课程表、208. 实现 Trie (前缀树)
算法·leetcode·图论
楼田莉子8 小时前
C++算法学习专题:滑动窗口
开发语言·数据结构·c++·学习·算法·leetcode
超级皮皮16 小时前
力扣热题之stack
算法·leetcode·职场和发展
YuTaoShao17 小时前
【LeetCode 热题 100】139. 单词拆分——(解法一)记忆化搜索
java·算法·leetcode·职场和发展
圣保罗的大教堂18 小时前
leetcode 1277. 统计全为 1 的正方形子矩阵 中等
leetcode
小欣加油1 天前
leetcode 904 水果成篮
c++·算法·leetcode
君万1 天前
【LeetCode每日一题】56. 合并区间
算法·leetcode·golang
墩墩同学1 天前
【LeetCode题解】LeetCode 287. 寻找重复数
算法·leetcode·二分查找
Elieal1 天前
Java 链表完全指南:从基础到力扣简单题实战
java·leetcode·链表
小南家的青蛙1 天前
LeetCode第55题 - 跳跃游戏
算法·leetcode·职场和发展