详解Go语言如何使用标准库sort对切片进行排序

作者:陈明勇 时间:2024-04-30 10:07:53 

sort 标准库

Sort 标准库提供了对基本数据类型的切片和自定义类型的切片进行排序的函数,常用函数如下表所示:

函数描述
Ints(x []int)对 int 类型的切片进行升序排序
IntsAreSorted(x []int) bool判断 int 类型的切片是否是升序排序
Float64s(x []float64)对 float64 类型的切片进行升序排序
Float64sAreSorted(x []float64) bool判断 float64 类型的切片是否是升序排序
Strings(x []string)对 string 类型的切片进行升序排序
StringsAreSorted(x []string) bool判断 string 类型的切片是否是升序排序
Sort(data Interface)对自定义类型的切片进行排序,自定义类型必须实现 Interface 接口

如果想了解更多函数的介绍和使用,可以到 pkg.go.dev/sort 进行查看。

Ints 和 IntsAreSorted

Ints(x []int):对 int 类型的切片进行排序,将切片作为参数进行传递,改变原切片的元素顺序

IntsAreSorted(x []int) bool,传递一个切片进去,判断此切片是否是升序排序,是则返回 true,否则返回 false

import (
   "fmt"
   "sort"
)

func main() {
   nums := []int{5, 3, 1, 2, 4, 7}
   fmt.Println("排序前:", nums)
   fmt.Println("切片是否是升序排序:", sort.IntsAreSorted(nums))
   sort.Ints(nums)
   fmt.Println("排序后:", nums)
   fmt.Println("切片是否是升序排序:", sort.IntsAreSorted(nums))
}

执行结果:

排序前: [5 3 1 2 4 7]
切片是否是升序排序: false
排序后: [1 2 3 4 5 7]
切片是否是升序排序: true

Float64s 和 Float64sAreSorted

Float64s(x []float64):对 float64 类型的切片进行排序,将切片作为参数进行传递,改变原切片的元素顺序

Float64sAreSorted(x []float64) bool,传递一个切片进去,判断此切片是否是升序排序,是则返回 true,否则返回 false

import (
   "fmt"
   "sort"
)

func main() {
   nums := []float64{0.0, 1.5, 1.0, 2.4, 4.4, 7.3}
   fmt.Println("排序前:", nums)
   fmt.Println("切片是否是升序排序:", sort.Float64sAreSorted(nums))
   sort.Float64s(nums)
   fmt.Println("排序后:", nums)
   fmt.Println("切片是否是升序排序:", sort.Float64sAreSorted(nums))
}

执行结果:

排序前: [0 1.5 1 2.4 4.4 7.3]
切片是否是升序排序: false
排序后: [0 1 1.5 2.4 4.4 7.3]
切片是否是升序排序: true

Strings 和 StringsAreSorted

Strings(x []string):对 float64 类型的切片进行排序,将切片作为参数进行传递,改变原切片的元素顺序

StringsAreSorted(x []string) bool,传递一个切片进去,判断此切片是否是升序排序,是则返回 true,否则返回 false

import (
   "fmt"
   "sort"
)

func main() {
   strs := []string{"d", "a", "c", "b"}
   fmt.Println("排序前:", strs)
   fmt.Println("切片是否是升序排序:", sort.StringsAreSorted(strs))
   sort.Strings(strs)
   fmt.Println("排序后:", strs)
   fmt.Println("切片是否是升序排序:", sort.StringsAreSorted(strs))
}

执行结果:

排序前: [d a c b]
切片是否是升序排序: false
排序后: [a b c d]
切片是否是升序排序: true

Sort

Sort(data Interface):对实现 Interface 接口的自定义集合类型按照自定义的规则进行排序。

Interface

实现 Interface 接口,需要实现以下三个方法:

Len() int 返回集合的长度

Less(i, j) bool

  • ij 为两个元素在集合里的下标值

  • 该方法返回一个 bool 值, 判断 i 位置的元素是否应该排在 j 之前,如果 bool 值为 false,则说明 i 不应该在 j 之前。

Swap(i, j int)

对结构体切片进行排序

import (
   "fmt"
   "sort"
)

type User struct {
   Name string
   Age  int
}

type UserSlice []User

func (us UserSlice) Len() int {
   return len(us)
}

func (us UserSlice) Less(i, j int) bool {
   return us[i].Age < us[j].Age
}

func (us UserSlice) Swap(i, j int) {
   us[i], us[j] = us[j], us[i]
}

func main() {
   us := UserSlice{
       User{Name: "小明", Age: 22},
       User{Name: "小红", Age: 17},
       User{Name: "小花", Age: 18},
   }
   fmt.Println("排序前:", us)
   sort.Sort(us)
   fmt.Println("排序后:", us)
}

执行结果:

排序前: [{小明 22} {小红 17} {小花 18}]
排序后: [{小红 17} {小花 18} {小明 22}]

  • 定义 User 结构体,自定义 UserSlice 类型,其基类为 []User User 切片

  • 实现 sort 包里的 Interface 接口,定义 LenLessSwap 函数

  • Less 函数的返回值逻辑为 return us[i].Age < us[j].Age,表示按照年龄字段进行升序排序

小结

本文介绍了如何使用 sort 包里的函数,对基本数据类型的切片进行排序。sort 包还提供了对自定义的集合进行排序,需要实现 Interface 接口,由使用者去自定义排序规则,通过 sort.Sort 函数进行排序。

来源:https://juejin.cn/post/7179260634872152119

标签:Go,sort,切片,排序
0
投稿

猜你喜欢

  • python解析html提取数据,并生成word文档实例解析

    2023-10-19 13:50:38
  • django如何自己创建一个中间件

    2021-03-31 10:26:59
  • 巧用Dreamweaver4文件库更新网站

    2007-02-03 11:31:00
  • Sqlserver 高并发和大数据存储方案

    2024-01-17 22:45:56
  • 详解Python3中的 input() 函数

    2022-09-21 19:50:59
  • Python3爬虫学习之应对网站反爬虫机制的方法分析

    2022-04-17 08:44:16
  • 如何Shrink Undo表空间,释放过度占用的空间

    2010-07-16 13:17:00
  • DW MX 的快键一览表

    2009-07-21 12:47:00
  • Pytorch 定义MyDatasets实现多通道分别输入不同数据方式

    2022-02-25 20:42:51
  • Python列表元素删除和remove()方法详解

    2023-04-07 08:48:54
  • Django 对IP访问频率进行限制的例子

    2022-02-14 05:40:38
  •  Go 语言实现 HTTP 文件上传和下载

    2023-06-23 01:42:24
  • sql中exists的基本用法示例

    2024-01-25 08:24:55
  • Python实现冒泡排序算法的示例解析

    2021-03-17 10:34:10
  • oracle命令行删除与创建用户的代码

    2009-03-02 10:54:00
  • 利用JavaScript做数独的完整实现过程

    2024-02-24 02:10:47
  • 如何增强网站数据库Access文件的安全性

    2008-11-13 16:58:00
  • python爬虫实例详解

    2021-07-05 01:37:53
  • python 实现在tkinter中动态显示label图片的方法

    2022-07-17 11:10:15
  • Windows8下安装Python的BeautifulSoup

    2022-05-30 15:03:06
  • asp之家 网络编程 m.aspxhome.com