go 递归实现快排
2024-10-21 09:14:39
package main import (
"fmt"
) func main() {
arr := []int{1,2,5,8,7,4,3,6,9,0,12,13,45,78,89,56,23,11,12,23,56,89,79,46,13,00,11,22,11,22,33,66,88,77,44,44,11,10,26}
//fmt.Println(len(arr))
fmt.Println(QuickSort(arr),len(QuickSort(arr)))
} func QuickSort(arr []int)[]int{
if len(arr) ==0 {
return []int{}
}
qmiddle := arr[0]
qleft := QuickSort(QuickLeft(arr, qmiddle))
qright := QuickSort(QuickRight(arr,qmiddle))
return append(append(qleft,qmiddle),qright...) //list = append(slice, data) list = append(slice1, slice2...) !
} func QuickLeft(arr []int, qmiddle int)[]int{
leftarr := []int{}
num := len(arr)
for i:= 1; i < num; i++{
if arr[i] <= qmiddle{
leftarr = append(leftarr,arr[i])
}
}
return leftarr
} func QuickRight(arr []int, qmiddle int)[]int{
rightarr := []int{}
num := len(arr)
for j:= 1; j < num; j++{
if arr[j] > qmiddle{
rightarr = append(rightarr,arr[j])
}
}
return rightarr
}
最新文章
- GMap.NET二次开发库
- SQL Server 2012 联机丛书安装
- 【Mxnet】----1、使用mxnet训练mnist数据集
- iOS7上的地图定位接口BUG
- 阿里巴巴开源Weex 开发教程
- linux secureCRT utf-8编码显示
- 面向XX编程
- soap实例入门(转)
- java事件处理3
- 用 gulp.spritesmith 自动化雪碧图
- 关于pthread_create未定义的引用的奇葩解决
- Educational Codeforces Round 22.B 暴力
- DevExtreme 学习应用[3]
- c#+wpf项目性能优化之OutOfMemoryException解密
- Linux for python教程02
- Github学习心得体会
- QT开发环境安装配置教程
- 求割点 割边 Tarjan
- Bridge桥接模式(结构型模式)
- 苹果ATS 豁免摆乌龙?