💝💝💝首先,欢迎各位来到我的博客,很高兴能够在这里和您见面!希望您在这里不仅可以有所收获,同时也能感受到一份轻松欢乐的氛围,祝你生活愉快!
插入排序是一种简单直观的排序算法,它的工作原理类似于人们整理手中的一叠卡片。该算法通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常使用in-place排序(即只需用到O(1)的额外空间),其时间复杂度为O(n^2),其中n是待排序数组的长度。
插入排序的基本思想是:
假设有一个数组 arr
需要进行排序。
arr[j]
。arr[j]
与已排序部分的元素 arr[i]
进行比较,如果 arr[j]
更小,则交换位置,否则继续与前面的元素比较。arr[j]
被正确插入到已排序部分。接下来,我们将通过一个示例来详细了解插入排序的实现步骤。
考虑一个整数数组 arr = [5, 2, 4, 6, 1, 3]
。
以下是插入排序的基本伪代码:
for i = 1 to n-1 do key = arr[i] j = i - 1 while j >= 0 and arr[j] > key do arr[j+1] = arr[j] j = j - 1 end while arr[j+1] = key end for
下面是一个使用Python编写的插入排序算法的具体实现:
def insertion_sort(arr): # 获取数组的长度 n = len(arr) # 从第二个元素开始遍历数组 for i in range(1, n): # 保存当前元素,它将被插入到已排序的部分 key = arr[i] # 初始化j为当前元素的前一个位置 j = i - 1 # 将大于key的元素向右移动一位 while j >= 0 and arr[j] > key: arr[j + 1] = arr[j] j -= 1 # 将key插入到正确的位置 arr[j + 1] = key return arr # 示例数组 arr = [5, 2, 4, 6, 1, 3] # 调用函数 sorted_arr = insertion_sort(arr) print(sorted_arr)
插入排序是一种简单有效的排序方法,尤其适用于小规模数组或者基本有序的数组。虽然它的平均和最坏时间复杂度较高,但在实际应用中,特别是当数据量不大时,它的性能是可以接受的。此外,插入排序还可以作为其他更复杂的排序算法的基础组成部分,比如希尔排序。
喜欢博主的同学,请给博主一丢丢打赏吧↓↓↓您的支持是我不断创作的最大动力哟!感谢您的支持哦😘😘😘
💝💝💝如有需要请大家订阅我的专栏【数据结构与算法】哟!我会定期更新相关系列的文章
💝💝💝关注!关注!!请关注!!!请大家关注下博主,您的支持是我不断创作的最大动力!!!
❤️❤️❤️觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄
💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍
🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙