数据结构和算法-插入排序实现|学习笔记

简介: 快速学习数据结构和算法-插入排序实现

开发者学堂课程【Go 语言核心编程 - 数据结构和算法:数据结构和算法-插入排序实现】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/627/detail/9850


数据结构和算法-插入排序实现


 考察代码算法怎么样是最基本的,现在就根据之前讲的做一下

image.png

接下来就是新建文件夹,还是用之前的数据。

package main

import(

"fmt"

)

func  Insertsort (arr"[5]int){

//完成第一次,给第二个元素找到合适的位置并插入

insertval:=arr[1]]

insertIndex :=1-1  //下标

//从大到小,就是要做一个后移的动作,就是把23往后移动,也很简单

for  insertIndex >=0 && arr[ InsertIndex ]<insertval{

Arr [insertIndex+1]=arr[insertIndex] //数据后移,要注意 insertIndex 先不动,后边的值等于前边的值就相当于把它覆盖了,不用担心,因为 insertval 已经被保存下来了。

insertIndex--

}

//插入

If  insertIndex+1!=1{

Arr[ insertIndex+1]=insertval

}

Fmt.println(“第一次插入后的结果”)

}

func main(){

arr:=[5]int{23,e, 12, 56, 34}

Fmt.println(“原始数组=”,arr)

Insert&sort(&arr)

Fmt.println(“main 函数”)

Fmt.println(arr)

}

发现代码是正确的,0本身就是这个位置,它就在原来的位置没有动,但是不遍历是不知道的,所以还需要比较一次,比较完了,相当于这个是效率最高的,刚好是最后,比一次就可以了。

//完成第二次,给第三个元素找到合适的位置并插入

insertval=arr[2]

insertIndex =2-1  //下标

//从大到小,就是要做一个后移的动作,就是把23往后移动,也很简单

for  insertIndex >=0 && arr[ InsertIndex ]<insertval{

Arr [insertIndex+1]=arr[insertIndex]  //数据后移,要注意

insertIndex 先不动,后边的值等于前边的值就相当于把它覆盖了,不用担心,因为 insertval 已经被保存下来了。

insertIndex--

}

//插入

If  insertIndex+1!=2{

Arr[ insertIndex+1]=insertval

}

Fmt.println(“第二次插入后的结果”)

}

第二次运行是正确的

//完成第三次,给第四个元素找到合适的位置并插入

insertval=arr[3]

insertIndex =3-1//下标

//从大到小,就是要做一个后移的动作,就是把23往后移动,也很简单

for  insertIndex >=0 && arr[ InsertIndex ]<insertval{

Arr [insertIndex+1]=arr[insertIndex] //数据后移,要注意 insertIndex 先不动,后边的值等于前边的值就相当于把它覆盖了,不用担心,因为 insertval 已经被保存下来了。

insertIndex--

}

//插入

If  insertIndex+1!=3{

Arr[ insertIndex+1]=insertval

}

Fmt.println(“第三次插入后的结果”)

}

第三次运行也是正确的,56最大就到前边去了,其余都向后移。

//完成第四次,给第五个元素找到合适的位置并插入

insertval=arr[4]

insertIndex =4-1 //下标

//从大到小,就是要做一个后移的动作,就是把23往后移动,也很简单

for  insertIndex >=0 && arr[ InsertIndex ]<insertval{

Arr [insertIndex+1]=arr[insertIndex] //数据后移,要注意 insertIndex 先不动,后边的值等于前边的值就相当于把它覆盖了,不用担心,因为 insertval 已经被保存下来了。

insertIndex--

} 

//插入

If  insertIndex+1!=4{

Arr[ insertIndex+1]=insertval

}

Fmt.println(“第四次插入后的结果”)

}

第四次也正确

五个元素四次,这四次是差不多一样的,只有一点地方不一样。

整合的代码:

//完成第一次,给第二个元素找到合适的位置并插入

for i:=1;ic len(arr);i++{

insertVal:=arr[i]

insertIndex :=1-i//下标

//从大到小

for  insertndex >=0&ərr[ 1nsertndex ]<1nsertVal{

arr[ 1nsertIndex +1]=arri[ insertTndex ]//数据后移

insertxndex --

//插入

if insertlndex+1!=i{

arr[ insertndex +1]=insertval

}

fmt, Print1n("第%d次插入后%v\n",*arr)

}

代码结果是正确的,添加两个数也是没有问题的。

每次只要改变 i 的值即可。

思路:

第一次,先找到第一个元素,insertval 这是个下标,是插入的,下标总是元素的前一个值,然后进行一个从大到小的排序,只要 insertIndex >=0 就可以一直找,

因为要防止一直找不到就到最前面去了,要插入的值比之前的值大才到最前边,说明应该继续往前走,走的时候要后移,后移的时候就是移动一下,后移之后 insertval 再移一下,因为要看前面有没有更合适的,等到整个循环遍历结束后,就说明这个值的位置找到了,

位置就应该是 insertIndex +1,插入的值就应该是 insertIndex +1这个下标,但是为了提高效率,要考虑 insertIndex +1到底有没有可能就是最后一个,就比如0,比较发现23就大,那这个位置就找到了,找到之后就没有必要自己再加注一次了,所以排除一下这个条件。

相关文章
|
3月前
|
存储 监控 安全
企业上网监控系统中红黑树数据结构的 Python 算法实现与应用研究
企业上网监控系统需高效处理海量数据,传统数据结构存在性能瓶颈。红黑树通过自平衡机制,确保查找、插入、删除操作的时间复杂度稳定在 O(log n),适用于网络记录存储、设备信息维护及安全事件排序等场景。本文分析红黑树的理论基础、应用场景及 Python 实现,并探讨其在企业监控系统中的实践价值,提升系统性能与稳定性。
73 1
|
3月前
|
存储 监控 算法
基于跳表数据结构的企业局域网监控异常连接实时检测 C++ 算法研究
跳表(Skip List)是一种基于概率的数据结构,适用于企业局域网监控中海量连接记录的高效处理。其通过多层索引机制实现快速查找、插入和删除操作,时间复杂度为 $O(\log n)$,优于链表和平衡树。跳表在异常连接识别、黑名单管理和历史记录溯源等场景中表现出色,具备实现简单、支持范围查询等优势,是企业网络监控中动态数据管理的理想选择。
83 0
|
7月前
|
存储 算法 Java
算法系列之数据结构-二叉树
树是一种重要的非线性数据结构,广泛应用于各种算法和应用中。本文介绍了树的基本概念、常见类型(如二叉树、满二叉树、完全二叉树、平衡二叉树、B树等)及其在Java中的实现。通过递归方法实现了二叉树的前序、中序、后序和层次遍历,并展示了具体的代码示例和运行结果。掌握树结构有助于提高编程能力,优化算法设计。
189 10
 算法系列之数据结构-二叉树
|
7月前
|
算法 Java
算法系列之数据结构-Huffman树
Huffman树(哈夫曼树)又称最优二叉树,是一种带权路径长度最短的二叉树,常用于信息传输、数据压缩等方面。它的构造基于字符出现的频率,通过将频率较低的字符组合在一起,最终形成一棵树。在Huffman树中,每个叶节点代表一个字符,而每个字符的编码则是从根节点到叶节点的路径所对应的二进制序列。
158 3
 算法系列之数据结构-Huffman树
|
7月前
|
算法 Java
算法系列之数据结构-二叉搜索树
二叉查找树(Binary Search Tree,简称BST)是一种常用的数据结构,它能够高效地进行查找、插入和删除操作。二叉查找树的特点是,对于树中的每个节点,其左子树中的所有节点都小于该节点,而右子树中的所有节点都大于该节点。
196 22
|
8月前
|
存储 机器学习/深度学习 算法
C 408—《数据结构》算法题基础篇—链表(下)
408考研——《数据结构》算法题基础篇之链表(下)。
200 30
|
6天前
|
存储 编解码 算法
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
|
8天前
|
传感器 机器学习/深度学习 算法
【使用 DSP 滤波器加速速度和位移】使用信号处理算法过滤加速度数据并将其转换为速度和位移研究(Matlab代码实现)
【使用 DSP 滤波器加速速度和位移】使用信号处理算法过滤加速度数据并将其转换为速度和位移研究(Matlab代码实现)
|
7天前
|
传感器 机器学习/深度学习 算法
【UASNs、AUV】无人机自主水下传感网络中遗传算法的路径规划问题研究(Matlab代码实现)
【UASNs、AUV】无人机自主水下传感网络中遗传算法的路径规划问题研究(Matlab代码实现)
|
6天前
|
机器学习/深度学习 传感器 算法
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
79 14

热门文章

最新文章