Skip to content

删除排序数组中的重复项-26 #8

@sl1673495

Description

@sl1673495

给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。

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

示例  1:

给定数组 nums = [1,1,2],

函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。

你不需要考虑数组中超出新长度后面的元素。
示例  2:

给定 nums = [0,0,1,1,1,2,2,3,3,4],

函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。

你不需要考虑数组中超出新长度后面的元素。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/remove-duplicates-from-sorted-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

思路

维护快慢指针,慢指针只有在遇到「和当前慢指针位置的值」不一样的值的时候,才向前进一位,并且把这个位置的值替换成新值。

说的口语化一点,就是慢指针乖乖的留在原地,只有当快指针遇到的值发生变化的时候(这个变化的界定,是通过对比「当前慢指针位置的值」来决定的),才会把慢指针前进一位,并且替换成快指针此时指向的「新变化值」。

更直观的话,直接看这个视频吧:
https://leetcode-cn.com/problems/remove-duplicates-from-sorted-array/solution/shi-ping-dong-hua-jie-xi-bao-ni-dong-by-novice2mas

题解

/**
 * @param {number[]} nums
 * @return {number}
 */
let removeDuplicates = function (nums) {
  // 快指针
  let i = 0;
  // 慢指针
  let j = 0;

  while (i < nums.length) {
    let fast = nums[i];
    let slot = nums[j];

    // 快慢不相等,说明找到了一个新的值
    // 把慢指针的位置更新,并且赋值成新的值,继续等待下一个新值。
    if (fast !== slot) {
      j++;
      nums[j] = num;
    }
    i++;
  }

  return j + 1;
};

Metadata

Metadata

Assignees

No one assigned

    Labels

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions