linux - Go: 如何交换 slice 中的两个元素?

查看:156
本文介绍了linux - Go: 如何交换 slice 中的两个元素?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

这两段代码的结果为什么不一样:

package main
import (
        "fmt"
)

func main() {
        test := []int{2, 1, 1}
        fmt.Println(findDuplicate(test))
}
func findDuplicate(nums []int) int {
    for i := 0; i < len(nums); i++ {
        if nums[i] != i+1 {
            if nums[i] == nums[nums[i]-1] {
                return nums[i]
            }
            /*
            tmp := nums[i]
            nums[i] = nums[nums[i]-1]
            nums[nums[i]-1] = tmp
            */
             nums[i], nums[nums[i]-1] = nums[nums[i]-1], nums[i]
        }
    }
    return 0
}

以上代码输出的结果是 1

package main
import (
        "fmt"
)

func main() {
        test := []int{2, 1, 1}
        fmt.Println(findDuplicate(test))
}
func findDuplicate(nums []int) int {
    for i := 0; i < len(nums); i++ {
        if nums[i] != i+1 {
            if nums[i] == nums[nums[i]-1] {
                return nums[i]
            }
          
            tmp := nums[i]
            nums[i] = nums[nums[i]-1]
            nums[nums[i]-1] = tmp
          
            //nums[i], nums[nums[i]-1] = nums[nums[i]-1], nums[i]
        }
    }
    return 0
}

以上代码输出的结果是 0

我的 Go 版本是 Go 1.8

解决方案

2种交换方式都没错,问题是第一种情况在交换的过程中nums[i]的值发生了变化

tmp := nums[i]
nums[i] = nums[nums[i]-1] //此处nums[i]的值改变了
nums[nums[i]-1] = tmp //下标nums[i]-1已经不是你想要的值了

改为下面这种就没问题了:

tmp := nums[nums[i]-1]
nums[nums[i]-1] = nums[i]
nums[i]  = tmp

这篇关于linux - Go: 如何交换 slice 中的两个元素?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆