Go语言如何提高快排的效率
时间:2022-05-06
本文章向大家介绍Go语言如何提高快排的效率,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
快排利用分治的思想,这里数组/切片分为两个部分,左边比哨兵小,右边比哨兵大,然后递归执行快排函数,这里有个很重要的因素是如果递归调用的时候用协程执行,左半部分数组和右半部分的数组分别传入作参数,所以不用考虑数据的同步问题。效果就像是一个协程调2个,两个调4个,4个调8个。时间复杂度会明显降低。 使用线程快排和使用协程快排会有什么区别,由于系统限制,线程的创建是有限的,当数组长度一旦很大,速度回明显降低,但是协程不会,测试了一个100w的随机数数组,排序的时间也只是在10ms左右。测试如下: |
---|
package main
import "math/rand"
import "fmt"
import "time"
func quickSort(values []int,left,right int){
temp:=values[left]
p:=left
i,j:=left,right
for i<=j{
for j>=p && values[j]>=temp{
j--
}
if j>=p{
values[p]=values[j]
p=j
}
for i<=p && values[i]<=temp{
i++
}
if i<=p{
values[p]=values[i]
p=i
}
}
values[p]=temp
if p-left>1{
quickSort(values,left,p-1)
//go quickSort(values,left,p-1)
}
if right-p>1{
quickSort(values,p+1,right)
//go quickSort(values,p+1,right)
}
}
func QuickSort(values []int){
quickSort(values,0,len(values)-1)
}
func main(){
ceshi :=make([]int,10000)
for i:=0 ; i<100; i++ {
ceshi[i]=rand.Intn(100)
}
start_time :=time.Now()
QuickSort(ceshi)
end_time :=time.Since(start_time)
fmt.Println("after sort",ceshi)
fmt.Println("count time ",end_time)
}
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Android仿微信语音消息的录制和播放功能
- Android如何自定义升级对话框示例详解
- Android Tiny集成图片压缩框架的使用
- 11个JavaScript代码重构最佳实践
- Android编程实现类似天气预报图文字幕垂直滚动效果的方法
- Android 中 Tweened animation的实例详解
- Android 媒体开发之MediaPlayer状态机接口方法实例解析
- Android读取资源文件的方法
- Android 基于IntentService的文件下载的示例代码
- Android开发之底图局部加载移动的方法示例
- Ubuntu18.04下解决Qt出现qt.qpa.plugin:Could not load the Qt platform plugin “xcb“问题
- ExpandableListView实现手风琴效果
- 组复制性能 | 全方位认识 MySQL 8.0 Group Replication
- Android 中View.onDraw(Canvas canvas)的使用方法
- Android API编程之Assets文件操作示例