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

题目描述

给你一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。
由于在某些语言中不能改变数组的长度,所以必须将结果放在数组nums的第一部分。更规范地说,如果在删除重复项之后有 k 个元素,那么 nums 的前 k 个元素应该保存最终结果。
将最终结果插入 nums 的前 k 个位置后返回 k 。
不要使用额外的空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。

实例代码

var removeDuplicates = function(nums) {
    if(nums.length===0) return 0;
    let slow=0,fast = 0;
    while(fast<nums.length){
        if(nums[fast]!==nums[slow])
        {
            slow++
            nums[slow] =nums[fast]
        }
        fast++
    }
    return slow+1
};

解释

采用快慢指针的思路进行删除。这里的快慢指针与之前环形链表那道题的用法又不同,上一道题是类似追击相遇问题,而这一道题则不是。快指针是在正常情况下都会向前移动,慢指针只有在符合条件时才会移动。

我们让慢指针 slow 走在后面,快指针 fast 走在前面探路,找到一个不重复的元素就赋值给 slow 并让 slow 前进一步。
这样,就保证了 nums[0..slow] 都是无重复的元素,当 fast 指针遍历完整个数组 nums 后,nums[0..slow] 就是整个数组去重之后的结果。
image
同样的我们也可以利用这个方法去解决链表重复项
83. 删除排序链表中的重复元素

posted @ 2022-10-14 00:36  含若飞  阅读(22)  评论(0编辑  收藏  举报