LeetCode27. 移除元素Golang版
1. 问题描述
给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。
不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。
说明:
为什么返回数值是整数,但输出的答案是数组呢?
请注意,输入数组是以「引用」方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。

2. 思路
同向双指针:右指针找到 != val 的元素,赋值给left指向的位置
3. 代码
代码1
func removeElement(nums []int, val int) int {
for i := 0; i < len(nums); i++ {
if nums[i] == val {
nums = append(nums[:i],nums[i+1:]...)
i--
}
}
return len(nums)
}
代码2
func removeElement(nums []int, val int) []int {
left, right := 0, 0
for right < len(nums) {
if nums[right] != val {
nums[left] = nums[right]
left++
right++
} else {
right++
}
}
return nums[:left]
}
这篇文章介绍了如何使用Go语言解决LeetCode题目27,即在不使用额外空间的情况下移除数组中等于特定值的元素。两种方法对比,包括原地修改数组的思路和代码实现。
1457

被折叠的 条评论
为什么被折叠?



