热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

golang合并排序

篇首语:本文由编程笔记#小编为大家整理,主要介绍了golang合并排序相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了golang 合并排序相关的知识,希望对你有一定的参考价值。




package main
import (
"fmt"
)
func main() {
items := []int{4, 202, 3, 9, 6, 5, 1, 43, 506, 2, 0, 8, 7, 100, 25, 4, 5, 97, 1000, 27}
sortedItems := mergeSort(items)
fmt.Println(sortedItems)
}
func mergeSort(items []int) []int {
var n = len(items)

if n == 1 {
return items
}

middle := int(n / 2)
var (
left = make([]int, middle)
right = make([]int, n-middle)
)
for i := 0; i if i left[i] = items[i]
} else {
right[i-middle] = items[i]
}
}

return merge(mergeSort(left), mergeSort(right))
}
func merge(left, right []int) (result []int) {
result = make([]int, len(left) + len(right))

i := 0
for len(left) > 0 && len(right) > 0 {
if left[0] result[i] = left[0]
left = left[1:]
} else {
result[i] = right[0]
right = right[1:]
}
i++
}

// Either left or right may have elements left; consume them.
// (Only one of the following loops will actually be entered.)
for j := 0; j result[i] = left[j]
i++
}
for j := 0; j result[i] = right[j]
i++
}

return
}


推荐阅读
author-avatar
素材火
优质网页素材http://www.sucaihuo.com/
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有