侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Golang 实现插入排序的方法示例(2种)

Go  /  管理员 发布于 7年前   292

再次研究了插入排序的概念:定义一个有序的数据序列a,将待排序的序列b中的数依次插入到a的合适位置,插入后仍然有序

总结其与冒泡、选择的区别在于,内部迭代的次数是逐渐增大的,二后两者随着排序进行迭代次数逐渐减少

尝试基于Go的实现:

插入排序都采用in-place在数组上实现。具体算法描述如下:

  • 从第一个元素开始,该元素可以认为已经被排序 取出下一个元素
  • 在已经排序的元素序列中从后向前扫描
  • 如果该元素(已排序)大于新元素,将该元素移到下一位置
  • 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置 将新元素插入到该位置后
  • 将新元素插入到该位置后
  • 重复步骤2~5

两种实现方式:1,新建切片; 2,在原切片中进行元素交换

方式一:新建切片

package mainimport "fmt"func main() { arr := []int{1, 0, 5, 7, 8, 5, 3, 6, 9, 2, 54, 33, 66} newArr := []int{} insertionSort(arr, &newArr) fmt.Println(newArr)}/**插入排序法:取原数组old中第一个值作为新数组中的第一个值,然后遍历old,将每个元素按照条件插入到新数组中时间复杂度:O(n^2)*/func insertionSort(old []int, new *[]int) { if len(*new) == len(old) { return } current := len(*new) *new = append(*new, old[current]) sort(*new) insertionSort(old, new)}func sort(arr []int) { for i := len(arr) - 1; i > 0; i-- { if arr[i] < arr[i-1] {  arr[i], arr[i-1] = arr[i-1], arr[i] } }}

注意:insertionSort()函数中的第二个参数为切片的指针,不然打印出来的的新数组为空

原因:虽然切片是指针传递,这是指切片内的各个元素是指针传递,对于切片本身仍是值传递

证明:

package testimport ( "fmt" "testing")func TestSlice(t *testing.T) { slice1 := []string{"zhang", "san"} fmt.Printf("%p\n", &slice1) fmt.Printf("%p\n", &slice1[1]) modify(slice1) fmt.Println(slice1)}func modify(data []string) { fmt.Printf("%p\n", &data) fmt.Printf("%p\n", &data[1]) data[1] = "si"}

打印结果:

0xc0420e4680
0xc0420e46b0
0xc0420e46c0
0xc0420e46b0
[zhang si]

引申:Go 语言里的引用类型有如下几个:切片、映射、通道、接口和函数类型。当声明上述类型的变量时,创建的变量被称作标头(header)值。从技术细节上说,字符串也是一种引用类型。每个引用类型创建的标头值是包含一个指向底层数据结构的指针。因为标头值是为复制而设计的,所以永远不需要共享一个引用类型的值。标头值里包含一个指针,因此通过复制来传递一个引用类型的值的副本,本质上就是在共享底层数据结构

结论:不会对切片进行增加或删除操作时(也就是长度不会改变),切片作为参数在函数间的传递不需使用指针。但是如果切片需要进行增加或删除元素的操作,并且原函数需要调用更新后的切片,那么在原函数调用其它函数时,就需要用切片的指针作为参数。

方式二:在原切片中进行元素交换

func method2(arr []int) { if len(arr) < 2 { return } for i := 1; i < len(arr); i++ { for j := i; j > 0; j-- {  if arr[j] < arr[j-1] {  arr[j], arr[j-1] = arr[j-1], arr[j]  } } }} 

由于不用创建新的切片,不用进行插入操作,只需要交换操作,所以要较方法一速度快些

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    Golang logrus 日志包及日志切割的实现
    下一条:
    golang实现http server提供文件下载功能
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2017-09
    • 2020-03
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-12
    • 2021-01
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-08
    • 2024-11
    • 2025-02
    • 2025-04
    • 2025-05
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客