go语言中sort包的实现方法与应用详解
来源:脚本之家
时间:2022-12-27 09:40:01 329浏览 收藏
来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《go语言中sort包的实现方法与应用详解》,介绍一下排序、go语言sort包,希望对大家的知识积累有所帮助,助力实战开发!
前言
Go语言的 sort 包实现了内置和用户定义类型的排序,sort包中实现了3种基本的排序算法:插入排序.快排和堆排序.和其他语言中一样,这三种方式都是不公开的,他们只在sort包内部使用.所以用户在使用sort包进行排序时无需考虑使用那种排序方式,sort.Interface定义的三个方法:获取数据集合长度的Len()方法、比较两个元素大小的Less()方法和交换两个元素位置的Swap()方法,就可以顺利对数据集合进行排序。sort包会根据实际数据自动选择高效的排序算法。
之前跟大家分享了Go语言使用sort包对任意类型元素的集合进行排序的方法,感兴趣的朋友们可以参考这篇文章:https://www.jb51.net/article/60893.htm
下面来看看sort包的简单示例:
type Interface interface { // 返回要排序的数据长度 Len() int //比较下标为i和j对应的数据大小,可自己控制升序和降序 Less(i, j int) bool // 交换下标为i,j对应的数据 Swap(i, j int) }
任何实现了 sort.Interface 的类型(一般为集合),均可使用该包中的方法进行排序。这些方法要求集合内列出元素的索引为整数。
这里我直接用源码来讲解实现:
1、源码中的例子:
type Person struct { Name string Age int } type ByAge []Person //实现了sort接口中的三个方法,则可以使用排序方法了 func (a ByAge) Len() int { return len(a) } func (a ByAge) Swap(i, j int) { a[i], a[j] = a[j], a[i] } func (a ByAge) Less(i, j int) bool { return a[i].Age2、Sort(data Interface)方法
//sort包只提供了这一个公开的公使用的排序方法, func Sort(data Interface) { // Switch to heapsort if depth of 2*ceil(lg(n+1)) is reached. //如果元素深度达到2*ceil(lg(n+1))则选用堆排序 n := data.Len() maxDepth := 0 for i := n; i > 0; i >>= 1 { maxDepth++ } maxDepth *= 2 quickSort(data, 0, n, maxDepth) }//快速排序 //它这里会自动选择是用堆排序还是插入排序还是快速排序,快速排序就是 func quickSort(data Interface, a, b, maxDepth int) { //如果切片元素少于十二个则使用希尔插入法 for b-a > 12 { // Use ShellSort for slices 1 { // Do ShellSort pass with gap 6 // It could be written in this simplified form cause b-a//堆排序 func heapSort(data Interface, a, b int) { first := a lo := 0 hi := b - a // Build heap with greatest element at top. //构建堆结构,最大的元素的顶部,就是构建大根堆 for i := (hi - 1) / 2; i >= 0; i-- { siftDown(data, i, hi, first) } // Pop elements, largest first, into end of data. //把first插入到data的end结尾 for i := hi - 1; i >= 0; i-- { data.Swap(first, first+i) //数据交换 siftDown(data, lo, i, first) //堆重新筛选 } }// siftDown implements the heap property on data[lo, hi). // first is an offset into the array where the root of the heap lies. func siftDown(data Interface, lo, hi, first int) { //hi为数组的长度 //这里有一种做法是把跟元素给取到存下来,但是为了方法更抽象,省掉了这部,取而代之的是在swap的时候进行相互交换 root := lo //根元素的下标 for { child := 2*root + 1 //左叶子结点下标 //控制for循环介绍,这种写法更简洁,可以查看我写的堆排序的文章 if child >= hi { break } //防止数组下标越界,判断左孩子和右孩子那个大 if child+1这个包中还有很多方法,这个包实现了很多方法,比如排序反转,二分搜索。排序通过 quickSort()这个方法来控制该调用快排还是堆排。
总结
今天关于《go语言中sort包的实现方法与应用详解》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于golang的内容请关注golang学习网公众号!
-
178 收藏
-
317 收藏
-
493 收藏
-
189 收藏
-
459 收藏
-
233 收藏
-
322 收藏
-
181 收藏
-
316 收藏
-
244 收藏
-
300 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 不安的魔镜
- 太详细了,已加入收藏夹了,感谢up主的这篇技术贴,我会继续支持!
- 2023-02-03 20:49:36
-
- 活力的手机
- 这篇文章真是及时雨啊,好细啊,受益颇多,码起来,关注大佬了!希望大佬能多写Golang相关的文章。
- 2023-02-03 02:44:21
-
- 曾经的百褶裙
- 感谢大佬分享,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢师傅分享文章!
- 2023-01-24 12:57:17
-
- 动人的吐司
- 这篇博文太及时了,细节满满,太给力了,码起来,关注师傅了!希望师傅能多写Golang相关的文章。
- 2023-01-22 06:38:47
-
- 眼睛大的黄豆
- 这篇博文太及时了,太细致了,真优秀,码起来,关注博主了!希望博主能多写Golang相关的文章。
- 2023-01-04 12:08:16
-
- 有魅力的树叶
- 这篇技术贴出现的刚刚好,楼主加油!
- 2023-01-03 15:07:41
-
- 要减肥的铅笔
- 太细致了,收藏了,感谢老哥的这篇文章内容,我会继续支持!
- 2023-01-03 00:13:05
-
- 怕孤独的薯片
- 这篇文章内容真及时,博主加油!
- 2023-01-02 12:47:24
-
- user_1671454250
- 太全面了,已收藏,感谢大佬的这篇技术文章,我会继续支持!
- 2023-01-01 17:14:46
-
- 有魅力的树叶
- 这篇技术贴太及时了,好细啊,太给力了,码住,关注作者了!希望作者能多写Golang相关的文章。
- 2022-12-30 14:06:43
-
- 虚心的手套
- 很棒,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢up主分享文章内容!
- 2022-12-30 08:56:00
-
- 糊涂的嚓茶
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享技术贴!
- 2022-12-28 20:47:39
-
- 碧蓝的百合
- 这篇技术贴太及时了,太细致了,赞 👍👍,已收藏,关注师傅了!希望师傅能多写Golang相关的文章。
- 2022-12-28 06:26:19