详解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
i
和j
为两个元素在集合里的下标值该方法返回一个
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
接口,定义Len
、Less
和Swap
函数Less
函数的返回值逻辑为return us[i].Age < us[j].Age
,表示按照年龄字段进行升序排序
小结
本文介绍了如何使用 sort
包里的函数,对基本数据类型的切片进行排序。sort
包还提供了对自定义的集合进行排序,需要实现 Interface
接口,由使用者去自定义排序规则,通过 sort.Sort
函数进行排序。
来源:https://juejin.cn/post/7179260634872152119


猜你喜欢
- 一、概述推荐使用参考网站: json在python中,json模块可以实现json数据的序列化和反序列化序列化:将可存放在内存中的pytho
- 前言这里给大家介绍一下利用Pycharm如何打包文件,并为文件设置图标。一、下载pyinstaller库1)点击win+r,输入cmd打开控
- 基于 SpringBoot与SpringSecurity整合 案例的修改:数据库 user 表注,密码是由 BCrypt 算法加密对应用户名
- 目录支持多种类型的过滤避免多个范围查询优化排序理解索引概念最简单的方式是通过一个案例来进行,以下就是这样的一个案例。假设我们需要设计一个在线
- 如下所示:###方法1:用shift函数,不用通过循环import pandas as pdimport numpy as npimport
- 在django项目根目录位置创建scrapy项目,django_12是django项目,ABCkg是scrapy爬虫项目,app1是djan
- 本文实例讲述了php广告加载类的用法,非常实用。分享给大家供大家参考。具体方法如下:该php广告加载类,支持异步与同步加载。需要使用Jque
- 列表 List列表是任意对象的集合,在 Python 中通过逗号分隔的对象序列括在方括号 ( [] ) 中people_list = [
- 一.多表关系MySQL多表之间的关系可以概括为:一对一、一对多/多对一关系,多对多一对一关系一个学生只有一张身份证;一张身份证只能对应一学生
- 训练用PyTorch编写的LSTM或RNN时,在loss.backward()上报错:RuntimeError: Trying to bac
- python发起http请求,并解析返回的json字符串的小demo,方便以后用到。#! /usr/bin/env python  
- 优化查询使用Explain语句分析查询语句Explain 用来分析 SELECT 查询语句,开发人员可以通过分析 Explain 结果来优化
- 什么是Batch NormalizationBatch Normalization是神经网络中常用的层,解决了很多深度学习中遇到的问题,我们
- 简单使用csv.DictReader()方法示例代码1:import csvf = open('sample','r
- 队、栈和链表一样,在数据结构中非常基础一种数据结构,同样他们也有各种各样、五花八门的变形和实现方式。但不管他们形式上怎么变,队和栈都有其不变
- 说下防止PHPDDOS发包的方法 if (eregi("ddos-udp",$read)) { fputs($verbi
- 关于书写习惯,遵循曾经总结过的风格标准,现在一点都没有变。并且近来翻看高手作品,横向连排似乎在大产品项目中逐渐成为主流,个人认为如此维护效率
- 1、get方法请求接口url:显而易见,就是接口的地址url啦headers:请求头,例如:content-type = applicati
- Python2默认是不支持中文的,一般我们在程序的开头加上#-*-coding:utf-8-*-来解决这个问题,但是在我用open()方法打
- 性能监控一、web项目(如gin中)1.使用ginpprofimport "github.com/DeanThompson/gin