leetcode传送门
题目大意:
给你一个有序数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/remove-duplicates-from-sorted-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路
- 设置两个指针,慢指针i,快指针j,即i<j(这里的指针是指元素位置信息,即数组下标,不是C语言中的地址)
- 为i设置初值i=0,j=1
- 对于指针i来说,数组 是一个初始大小为1的动态数组,需要不断地通过j来找到与num[i]不相等的元素,然后在数组后面push新元素(条件是nums[i])
解法实现:
/**
* @param {number[]} nums
* @return {number}
*/
var removeDuplicates = function(nums) {
//特判
if( nums.length === 0)
return 0;
let i,j;
i = 0;
for(j = 1; j < nums.length; j ++) {
if(nums[i] !== nums[j]) {
i ++;
nums[i] = nums[j];
}
}
return i + 1;
};
review:
O(1) 额外空间的条件下完成