Golang 在slice中搜索一个float64类型的元素
在Go语言中slice比数组更加强大、灵活、方便,是一种轻量级的数据结构。slice是一个可变长度的序列,它存储相似类型的元素,你不允许在同一个slice中存储不同类型的元素。
在Go slice中,你可以借助 SearchFloat64s() 函数在给定的float64s slice中搜索一个float64类型元素。这个函数在一个排序的float64s片断中搜索给定的元素,如果在给定的片断中存在,则返回该元素的索引。如果给定的元素在片断中不存在(可能是len(s_slice)),那么它返回在片断中插入该元素的索引。指定的片断必须以升序排序。它是在sort包下定义的,所以你必须在你的程序中导入sort包以访问SearchFloat64s函数。
语法
func SearchFloat64s(s_slice []float64, f float64) int
例1 :
// Go program to illustrate how to search an
// element float64 type in the slice of float64s
package main
import (
"fmt"
"sort"
)
// Main function
func main() {
// Creating and initializing
// slice of Float64s
// Using shorthand declaration
slice_1 := []float64{45.667, 34545.5, 655.45,
768.8, 79.1, 10.2, 34.67}
slice_2 := []float64{56.78, 67.89, 10.7,
345.6, 89.4, 45.8}
var f1, f2, f3 float64
f1 = 34545.5
f2 = 67.89
f3 = 10.7
// Sorting the given slice of Float64s
sort.Float64s(slice_1)
sort.Float64s(slice_2)
// Displaying the slices
fmt.Println("Slice 1: ", slice_1)
fmt.Println("Slice 2: ", slice_2)
// Searching an element of float64
// in the given slice
// Using SearchFloat64s function
res1 := sort.SearchFloat64s(slice_1, f1)
res2 := sort.SearchFloat64s(slice_2, f2)
res3 := sort.SearchFloat64s(slice_2, f3)
// Displaying the results
fmt.Println("Result 1: ", res1)
fmt.Println("Result 2: ", res2)
fmt.Println("Result 3: ", res3)
}
输出
Slice 1: [10.2 34.67 45.667 79.1 655.45 768.8 34545.5]
Slice 2: [10.7 45.8 56.78 67.89 89.4 345.6]
Result 1: 6
Result 2: 3
Result 3: 0
例2 :
// Go program to illustrate how to search an
// element of float64 type in the slice of
// float64s
package main
import (
"fmt"
"sort"
)
// Main function
func main() {
// Creating and searching an element
// in the given slice of float64s
// Using SearchFloat64s function
res1 := sort.SearchFloat64s([]float64{23.4,
56.7, 90.7}, 56.7)
res2 := sort.SearchFloat64s([]float64{10.2,
13.90, 25.78, 38.90}, 10.2)
// Displaying the results
fmt.Println("Result 1: ", res1)
fmt.Println("Result 2: ", res2)
}
输出
Result 1: 1
Result 2: 0