golang实现十大经典算法:插入排序

使用Golang实现插入排序
本文探讨了插入排序的要点,强调其在原数组有序时的高效性和稳定性。由于Golang数组不支持直接插入操作,文章说明了如何通过自定义方法来实现插入排序。

插入排序的要点是找一个合理的位置插进入

插入排序优点:原数组有序会非常快,稳定

golang数组没有插入的操作,所以得自己实现

	a := []int{1,3,4,52,2,5,7,3,7,9}
	for i:=1;i<len(a);i++{
		todo := true
		for j:=i-1;j>=0;j--{
			if a[j]<a[i]{
				todo = false
				break
			}
			if j>0&&a[j]>=a[i] && a[i]>a[j-1]{
				todo = false
				mid := a[i]
				a = append(a[:i],a[i+1:]...)//将待插元素挪出来
				tmp := append([]int{},a[j:]...)//保存 插入位置后面所有元素
				sli := append(a[:j],mid)//将待插元素放入
				a = append(sli,tmp...)//合并
				break
			}
		}
		if todo==true{//说明最小插入到头部
			mid := a[i]
			a = append(a[:i],a[i+1:]...)
			sli := append(a[:0],mid)
			a = append(sli,a...)
		}
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值