技术文摘
以 Go 语言学习归并排序算法
2024-12-31 02:32:53 小编
以 Go 语言学习归并排序算法
在编程的世界里,排序算法是基础且重要的一部分。归并排序作为一种高效的排序算法,以其稳定的性能和良好的时间复杂度在众多算法中脱颖而出。在 Go 语言中学习和实现归并排序,不仅能加深对算法的理解,还能提升我们的编程能力。
归并排序(Merge Sort)是建立在归并操作上的一种有效、稳定的排序算法,其时间复杂度为 O(n log n)。基本思想是将一个序列分成两个子序列,分别对这两个子序列进行排序,然后将排好序的子序列合并成一个最终的有序序列。
下面是用 Go 语言实现归并排序的核心代码:
package main
import "fmt"
// 合并两个已排序的子数组为一个排序数组
func merge(arr []int, l int, m int, r int) {
n1 := m - l + 1
n2 := r - m
// 创建临时数组
left := make([]int, n1)
right := make([]int, n2)
// 复制数据到临时数组
for i := 0; i < n1; i++ {
left[i] = arr[l+i]
}
for j := 0; j < n2; j++ {
right[j] = arr[m+1+j]
}
// 初始化索引
i, j, k := 0, 0, l
// 合并临时数组回到 arr
for i < n1 && j < n2 {
if left[i] <= right[j] {
arr[k] = left[i]
i++
} else {
arr[k] = right[j]
j++
}
k++
}
// 复制剩余元素
for i < n1 {
arr[k] = left[i]
i++
k++
}
for j < n2 {
arr[k] = right[j]
j++
k++
}
}
// 归并排序函数
func mergeSort(arr []int, l int, r int) {
if l < r {
m := l + (r-l)/2
mergeSort(arr, l, m)
mergeSort(arr, m+1, r)
merge(arr, l, m, r)
}
}
// 打印数组函数
func printArray(arr []int, size int) {
for i := 0; i < size; i++ {
fmt.Printf("%d ", arr[i])
}
fmt.Println()
}
func main() {
arr := []int{12, 11, 13, 5, 6}
n := len(arr)
fmt.Println("排序前的数组为:")
printArray(arr, n)
mergeSort(arr, 0, n-1)
fmt.Println("排序后的数组为:")
printArray(arr, n)
}
在上述代码中,我们首先定义了 merge 函数用于合并两个已排序的子数组。然后,mergeSort 函数通过递归的方式将数组不断分成两半,直到子数组的长度为 1,再进行合并操作。
通过使用 Go 语言实现归并排序算法,我们可以更加深入地理解递归、函数调用以及数组操作等编程概念。在实际应用中,归并排序也能有效地处理大规模数据的排序需求。
掌握归并排序算法并用 Go 语言实现它,对于提升我们的算法和编程能力有着重要的意义。希望大家通过不断的实践和探索,能够更加熟练地运用归并排序以及其他优秀的算法来解决各种实际问题。
- 删除题目后怎样确保自动抽题系统题目数量与数据库 ID 一致
- 怎样查看MySQL单个索引的磁盘空间使用状况
- 数据库查询统计数据:实时 SQL 与异步 SQL 的选择
- Laravel 轻松整合微信与支付宝支付的方法
- MySQL 中 GROUP BY 子句字段要求:早期版本与 5.7 版本及后续版本的差异
- 数据库查询中聚合函数与排序的执行顺序是怎样的
- MySQL子查询更新表时加一层包裹可解决报错的原因
- MySQL 中 `update join` 语句使用 `order by` 会引发什么问题
- 互联网时代数据库视图的应用场景:是否仍有用武之地
- GoFly 快速开发框架:开发者现状及应用场景剖析
- PHPExcel 如何将模板中的图片数据导出至 Excel
- Prisma操作MySQL数据时间少8小时的原因探讨
- Laravel 框架下如何实现微信与支付宝支付的高效集成
- MySQL 中 WHERE 子句多字段条件时锁机制的工作原理
- Python 连接 MySQL 检索数据时遇到 "" 报错如何解决