登录
首页 >  Golang >  Go问答

golang中是否有任何函数可以查找值是否在数组中?

来源:stackoverflow

时间:2024-04-16 13:51:35 168浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《golang中是否有任何函数可以查找值是否在数组中?》,以下内容主要包含等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

问题内容

假设有一个切片,里面有整数。我们已经声明了一个包含整数值的变量,然后我必须在不使用 for 循环的情况下从该切片中找到该值。

使用 for 循环我喜欢这样:-

package main

import (
   "fmt"
)

func main() {
  value := 10
  var interf []interface{}
  for i := 1; i <= value; i++{
    interf = append(interf, i)
  } 
  fmt.Println(interf)
  for _,v := range interf{
    if value == v{
       fmt.Println("Matched")
    }
  }
}

我们如何在不使用 for 循环的情况下完成同样的事情


解决方案


如果没有 for 循环,则没有*(请参阅 How to search for an element in a golang slice)。

* 实际上,您可以使用递归函数在没有 for 循环的情况下完成此操作。请参阅答案末尾的解决方案。

标准库中没有现成的函数,但您自己创建一个函数是多么容易:

func find(what interface{}, where []interface{}) (idx int) {
    for i, v := range where {
        if v == what {
            return i
        }
    }
    return -1
}

并使用它:

what := 10
where := []interface{}{1, 2, 3, 10, 5}
fmt.println(find(what, where))

输出(在 Go Playground 上尝试):

3

另请注意,使用 []int 切片类型代替 []interface{} 会更快、更方便:

func find(what int, where []int) (idx int) {
    for i, v := range where {
        if v == what {
            return i
        }
    }
    return -1
}

然后使用它:

what := 10
where := []int{1, 2, 3, 10, 5}
fmt.println(find(what, where))

输出是一样的。在 Go Playground 上试试这个。

您可以使用 interface{} 类型创建一个接受任何类型切片的函数,但这需要反射来实现它,这会比较慢并且不值得使用。相反,如果需要,只需创建一个具有具体切片类型的函数,或者直接使用 for 循环即可。

为了完整起见,这里的解决方案不使用 for 循环,而是使用递归函数。这仅用于教育目的,上面的解决方案优于此:

func find(what int, where []int) (idx int) {
    if len(where) == 0 {
        return -1
    }
    if what == where[0] {
        return 0
    }
    if idx = find(what, where[1:]); idx < 0 {
        return -1 // Not found in the rest of the slice
    }
    return 1 + idx
}

拨打 Go Playground 试试这个。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《golang中是否有任何函数可以查找值是否在数组中?》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>