日韩高清在线日韩大片观看网址,一级毛片毛片**毛片毛片,女**毛片一级毛片一,狠狠插天天干,天天干夜夜噜,亚洲人成在线免费观看,天天操天天草

Go-標(biāo)準(zhǔn)庫(kù)-sort(二)-世界新視野

  • 騰訊云
  • 2023-04-28 01:15:12

func Strings(a []string)

Strings函數(shù)對(duì)string類型的切片進(jìn)行升序排序。

示例:


(資料圖)

package mainimport (    "fmt"    "sort")func main() {    arr := []string{"apple", "banana", "pear", "orange", "grape"}    sort.Strings(arr)    fmt.Println(arr) // Output: [apple banana grape orange pear]}

func Reverse(data Interface) Interface

Reverse函數(shù)返回一個(gè)實(shí)現(xiàn)了sort.Interface接口的新對(duì)象,該對(duì)象可以對(duì)被排序的元素進(jìn)行反向排序。

示例:

package mainimport (    "fmt"    "sort")type myInts []intfunc (a myInts) Len() int           { return len(a) }func (a myInts) Swap(i, j int)      { a[i], a[j] = a[j], a[i] }func (a myInts) Less(i, j int) bool { return a[i] < a[j] }func main() {    arr := myInts{3, 1, 4, 1, 5, 9, 2, 6, 5, 3}    sort.Sort(sort.Reverse(arr))    fmt.Println(arr) // Output: [9 6 5 5 4 3 3 2 1 1]}

上面的例子中,我們定義了一個(gè)myInts類型,該類型實(shí)現(xiàn)了sort.Interface接口。然后,我們使用sort.Reverse函數(shù)對(duì)myInts類型的切片進(jìn)行反向排序。

func Search(n int, f func(int) bool) int

Search函數(shù)使用二分查找算法在長(zhǎng)度為n的有序切片中查找滿足f函數(shù)的最小索引。如果不存在這樣的索引,則返回n。

示例:

package mainimport (    "fmt"    "sort")func main() {    arr := []int{1, 3, 5, 7, 9}    fmt.Println(sort.Search(len(arr), func(i int) bool { return arr[i] >= 5 })) // Output: 2}

上面的例子中,我們定義了一個(gè)長(zhǎng)度為5的有序整型切片,并使用sort.Search函數(shù)查找大于或等于5的元素的最小索引。由于切片中的第3個(gè)元素為5,因此該函數(shù)返回2。

func SearchInts(a []int, x int) int

SearchInts函數(shù)使用二分查找算法在已排序的整型切片a中查找x的索引。如果x不存在于a中,則返回值為將x插入a后的索引。

示例:

package mainimport (    "fmt"    "sort")func main() {    arr := []int{1, 3, 5, 7, 9}    fmt.Println(sort.SearchInts(arr, 5)) // Output: 2}

上面的例子中,我們定義了一個(gè)長(zhǎng)度為5的有序整型切片,并使用sort.SearchInts函數(shù)查找5的索引。由于切片中的第3個(gè)元素為5,因此該函數(shù)返回2。

關(guān)鍵詞:

分享到:
?
  • 至少輸入5個(gè)字符
  • 表情

熱門資訊