跟着动画学Go数据结构之冒泡排序 #私藏项目实操分享#

简介: 跟着动画学Go数据结构之冒泡排序 #私藏项目实操分享#

冒泡排序

冒泡排序是一种最简单的交换排序算法。

什么是交换?交换就是两两进行比较,如果不满足次序就可以交换位置。比如,我们想要从小到大排序,通过两个位置上的值两两比较,如果逆序就交换,使关键字大的记录像泡泡一样冒出来放在末尾。

重复执行若干次冒泡排序,最终得到有序序列。

冒泡排序的名字来源于:值较小的元素如同”气泡“一样逐渐漂浮到序列的顶端。

思想

  1. 给定一个N个元素的数组,冒泡法排序将:

如果元素大小关系不正确,交换这两个数(在本例中为a> b),

  1. 比较一对相邻元素(a,b),
  2. 重复步骤1和2,直到我们到达数组的末尾(最后一对是第(N-2)和(N-1)项,因为我们的数组从零开始)
  3. 到目前为止,最大的元素将在最后的位置。 然后我们将N减少1,并重复步骤1,直到N = 1。

动画演示

给定一个数组 29, 10, 14, 37, 14, 48, 17 ,经过冒泡排序的动画如下所示:

1.gif

代码实现

package main
import "fmt"
func main() {
    // index starts from 0
    var nums = []int{29, 10, 14, 37, 14, 48, 17}
    var length = len(nums)
    fmt.Println("原数组:", nums)
    bubbleSort(nums, length)
    fmt.Print("数组排序后:")
    for i := 0; i < length; i++ {
        fmt.Printf("%d\t", nums[i])
    }
}
func bubbleSort(nums []int, length int) {
    for i := 0; i < length-1; i++ {
        for j := 0; j < length-i-1; j++ {
            if nums[j] > nums[j+1] { // 如果大,交换
                var temp = nums[j] // 临时变量保存前一个值
                nums[j] = nums[j+1]
                nums[j+1] = temp
            }
        }
    }
}

运行上述代码,可以看到排序的结果:

[Running] go run "e:\Coding Workspaces\LearningGoTheEasiestWay\Go 数据结构\冒泡排序\main.go"
原数组: [29 10 14 37 14 48 17]
数组排序后:10    14  14  17  29  37  48

冒泡排序的优化

可以附加一个标志来改进该算法,在排序过程中,如果没有交换操作意味着排序完成。如果序列已经是有序的,则可以通过判断该标记来结束算法。

func bubbleSortImproved(nums []int, length int) {
    swapped := true
    for i := 0; i < length-1; i++ {
        for j := 0; j < length-i-1; j++ {
            if nums[j] > nums[j+1] {    // 如果大,交换
                var temp = nums[j]      // 临时变量保存前一个值
                nums[j] = nums[j+1]
                nums[j+1] = temp
                swapped = false         //如果没有出现这步骤,说明没有需要交换的了
            }
        }
        if swapped {    // 从头到尾都没有进行交换,说明已经排序完成
            break
        }
    }
}

在最好情况下,改进的冒泡算法的时间复杂度为

网络异常,图片无法展示
|
.

优化二,记录发生交换的位置

func BubbleBestSort(a []int) {
    lastSwap := len(a) - 1
    lastSwapTemp := len(a) - 1
    for j := 0; j < len(a)-1; j++ {
        lastSwap = lastSwapTemp
        for i := 0; i < lastSwap; i++ {
            if a[i] > a[i+1] {
                a[i], a[i+1] = a[i+1], a[i]
                lastSwapTemp = i
            }
        }
        if lastSwap == lastSwapTemp {
            break
        }
    }

总结

想对比其他排序算法的优点是,它能够检测输入序列是否已经是排序的。

image.png

相关文章
|
5月前
|
存储 Go 容器
深入探究Go语言中的数据结构
深入探究Go语言中的数据结构
96 3
|
2月前
|
存储 安全 Go
Go语言中的map数据结构是如何实现的?
Go 语言中的 `map` 是基于哈希表实现的键值对数据结构,支持快速查找、插入和删除操作。其原理涉及哈希函数、桶(Bucket)、动态扩容和哈希冲突处理等关键机制,平均时间复杂度为 O(1)。为了确保线程安全,Go 提供了 `sync.Map` 类型,通过分段锁实现并发访问的安全性。示例代码展示了如何使用自定义结构体和切片模拟 `map` 功能,以及如何使用 `sync.Map` 进行线程安全的操作。
|
7月前
|
JSON 运维 Go
Go 项目配置文件的定义和读取
Go 项目配置文件的定义和读取
|
4月前
|
Go API 数据库
Go 语言中常用的 ORM 框架,如 GORM、XORM 和 BeeORM,分析了它们的特点、优势及不足,并从功能特性、性能表现、易用性和社区活跃度等方面进行了比较,旨在帮助开发者根据项目需求选择合适的 ORM 框架。
本文介绍了 Go 语言中常用的 ORM 框架,如 GORM、XORM 和 BeeORM,分析了它们的特点、优势及不足,并从功能特性、性能表现、易用性和社区活跃度等方面进行了比较,旨在帮助开发者根据项目需求选择合适的 ORM 框架。
310 4
|
4月前
|
存储 JSON Go
如何在 Go 项目中隐藏敏感信息,比如避免暴露用户密码?
在Go语言开发中,用户信息管理常涉及敏感数据如密码的处理。为防止这些数据暴露给客户端,本文介绍了三种方法:使用JSON标签忽略字段、自定义序列化逻辑、使用数据传输对象(DTO),以确保用户数据的安全性。通过这些方法,可以有效控制数据输出,避免敏感信息泄露。
69 1
|
4月前
|
中间件 Go API
Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架
本文概述了Go语言中几种流行的Web框架,如Beego、Gin和Echo,分析了它们的特点、性能及适用场景,并讨论了如何根据项目需求、性能要求、团队经验和社区支持等因素选择最合适的框架。
293 1
|
5月前
|
SQL 关系型数据库 MySQL
Go语言项目高效对接SQL数据库:实践技巧与方法
在Go语言项目中,与SQL数据库进行对接是一项基础且重要的任务
142 11
|
5月前
|
Go
使用go语言将A助手加入项目中
使用go语言将A助手加入项目中
36 2
|
5月前
|
算法 搜索推荐
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
本文介绍了冒泡排序、选择排序和插入排序三种基础排序算法的原理、实现代码和测试结果。
46 0
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
|
5月前
|
存储 Kubernetes Go
Go语言项目组织架构
Go语言项目组织架构

热门文章

最新文章