算法练习之删除已排序数组中的重复项

题目描述:给定一个已排序数组,原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不使用额外的数组空间,必须在原地修改输入数组并在使用O910额外空间的条件下完成。

解答:

数组完成排序后,我们可以放置两个指针 i 和 j,其中 i 是慢指针,而 j 是快指针。只要 nums[i] = nums[j],我们就增加 j 以跳过重复项。

当我们遇到 nums[j] ≠ nums[i] 时,跳过重复项的运行已经结束,因此我们必须把它(nums[j])的值复制到 nums[i + 1]。然后递增 i,接着我们将再次重复相同的过程,直到 j 到达数组的末尾为止。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
func removeDuplicates(_ nums: inout [Int]) -> Int {
if nums.count == 0 {return 0}
var i = 0
for j in 0 ..< nums.count {
if nums[i] != nums[j] {
i += 1
nums[i] = nums[j]
}
}
return i + 1
}

var nums:[Int] = [1, 1, 2, 2, 3]
let index = (removeDuplicates(&nums)) // 3
nums.prefix(upTo: index) // [1, 2, 3]

算法练习之删除已排序数组中的重复项

https://oxo.red/delete_repeated_element_from_sorted_array/

作者

Han

发布于

2018-06-26

更新于

2021-08-20

许可协议

评论