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-- } }
以上是在 Golang 中反转数组而不改变负数位置的详细内容。更多信息请关注PHP中文网其他相关文章!