php小编百草在Golang中反转数组而不改变负数位置是一个常见的问题。在处理数组反转时,通常会使用一种简单直接的方法,即使用两个指针分别指向数组的头部和尾部,然后交换它们的值,直到两个指针相遇。但是,如果数组中存在负数,我们可能需要保持它们的位置不变。为了解决这个问题,我们可以使用两个辅助数组,一个用于存储正数,另一个用于存储负数。然后,我们分别对这两个数组进行反转操作,最后再将它们合并起来。这样就可以实现在不改变负数位置的情况下反转整个数组。这种方法简单有效,可以在Golang中轻松实现。
问题内容
我想反转数组而不更改负数位置。下面是我尝试过的程序,我在这里缺少一些简单的逻辑。任何帮助将不胜感激。
package main
import "fmt"
func swapContents1(listObj []int) {
i, j := 0, len(listObj)-1
for i < j {
if listObj[i] < 0 {
i++
}
if listObj[j] < 0 {
j--
}
listObj[i], listObj[j] = listObj[j], listObj[i]
i++
j--
}
}
func main() {
listObj := []int{1, 2, 3, -4, 5, -6, -7}
swapContents1(listObj)
fmt.Println(listObj)
}
预期输出:[5 3 2 -4 1 -6 -7]
我得到的输出:[-6 5 3 -4 2 1 -7]
解决方法
你已经非常接近了,你只需要在检查数字是否为负的条件之后添加 continue
。所以你的 swapContents1
函数将如下所示:
func swapContents1(listObj []int) {
i, j := 0, len(listObj)-1
for i < j {
if listObj[i] < 0 {
i++
continue
}
if listObj[j] < 0 {
j--
continue
}
listObj[i], listObj[j] = listObj[j], listObj[i]
i++
j--
}
}