go语言中sort包的实现方法与应用详解
来源:脚本之家
2022-12-27 09:40:01
0浏览
收藏
来到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].Age <p><strong>2、Sort(data Interface)方法</strong></p> <pre class="brush:js;"> //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 <pre class="brush:js;"> //堆排序 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 <p>这个包中还有很多方法,这个包实现了很多方法,比如排序反转,二分搜索。排序通过 quickSort()这个方法来控制该调用快排还是堆排。</p> <p><span style="color: #ff0000"><strong>总结</strong></span></p> <p>今天关于《go语言中sort包的实现方法与应用详解》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于golang的内容请关注golang学习网公众号!</p>
版本声明
本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除

- 上一篇
- Go语言程序查看和诊断工具详解

- 下一篇
- Go语言排序算法之插入排序与生成随机数详解
评论列表
-
- 不安的魔镜
- 太详细了,已加入收藏夹了,感谢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
查看更多
最新文章
-
- Golang · Go教程 | 3分钟前 |
- Golang性能测试指标解析与基准测试分析
- 218浏览 收藏
-
- Golang · Go教程 | 10分钟前 |
- Gin框架构建RESTAPI入门教程
- 490浏览 收藏
-
- Golang · Go教程 | 11分钟前 |
- Golang微服务架构实现详解
- 105浏览 收藏
-
- Golang · Go教程 | 21分钟前 |
- Golang变量定义技巧全解析
- 486浏览 收藏
-
- Golang · Go教程 | 24分钟前 |
- Golang原子替换:rename实现与事务解析
- 386浏览 收藏
-
- Golang · Go教程 | 32分钟前 |
- Golang访问者模式实现与对象扩展方法
- 457浏览 收藏
-
- Golang · Go教程 | 33分钟前 |
- Golangchannel详解:无缓冲与有缓冲区别
- 366浏览 收藏
-
- Golang · Go教程 | 36分钟前 |
- Go语言无符号表解析详解
- 331浏览 收藏
-
- Golang · Go教程 | 45分钟前 |
- Golangswitch语句使用技巧解析
- 167浏览 收藏
-
- Golang · Go教程 | 49分钟前 |
- Golang大内存处理技巧:mmap与滑动窗口解析
- 448浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
查看更多
AI推荐
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 98次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 89次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 109次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 99次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 100次使用
查看更多
相关文章
-
- Go语言实现常用排序算法的示例代码
- 2022-12-31 178浏览
-
- golang中按照结构体的某个字段排序实例代码
- 2022-12-24 317浏览
-
- Golang中Map按照Value大小排序的方法实例
- 2023-02-18 493浏览
-
- 详解go语言中sort如何排序
- 2023-01-07 189浏览
-
- golang编程开发使用sort排序示例详解
- 2023-02-25 459浏览