算法-插入排序

简介: 插入排序是一种排序算法,它在每次迭代中将未排序的元素放置在合适的位置。虽然使用起来很简单,但它不适用于大型数据集,因为插入排序在平均情况和最坏情况下的时间复杂度为O(n 2 ),其中 n 是项目数。插入排序的效率低于其他排序算法,如堆排序、快速排序、合并排序等。

一、简介

插入排序是一种排序算法,它在每次迭代中将未排序的元素放置在合适的位置。虽然使用起来很简单,但它不适用于大型数据集,因为插入排序在平均情况和最坏情况下的时间复杂度为O(n 2 ),其中 n 是项目数。插入排序的效率低于其他排序算法,如堆排序、快速排序、合并排序等。

插入排序的工作原理类似于我们在纸牌游戏中对手中的纸牌进行排序。

我们假设第一张卡片已经排序,然后我们选择一张未排序的卡片。如果未排序的卡片大于手牌,则将其放在右侧,否则放在左侧。以同样的方式,其他未分类的卡片被取出并放在正确的位置。

插入排序优点:

  • 简单的实现
  • 对小型数据集有效
  • 自适应,即它适用于已经基本排序的数据集。

二、工作原理

假设我们需要对以下数组进行排序,需要进行以下步骤:

初始化数组

  1. 假定数组中的第一个元素已排序。取出第二个元素并将其单独存储在key中,并与第一个元素进行比较。如果第一个元素大于key,则把key放在第一个元素的前面。

如果第一个元素大于 key,则将 key 放在第一个元素的前面

  1. 现在,前两个元素已排序。取第三个元素并将其与左侧的元素进行比较。将它放在比它小的元素后面。如果没有比它小的元素,则将其放在数组的开头。

  1. 同样,将每个未排序的元素放在正确的位置。

三、JAVA实现

importjava.util.Arrays;
classInsertionSort {
voidinsertionSort(intarray[]) {
intsize=array.length;
for (intstep=1; step<size; step++) {
intkey=array[step];
intj=step-1;
// Compare key with each element on the left of it until an element smaller than// it is found.// For descending order, change key<array[j] to key>array[j].while (j>=0&&key<array[j]) {
array[j+1] =array[j];
--j;
      }
// Place key at after the element just smaller than it.array[j+1] =key;
    }
  }
//由此可以看出插入排序的时间复杂度为O(n 2 )


相关文章
|
20天前
|
算法 搜索推荐
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
本文介绍了冒泡排序、选择排序和插入排序三种基础排序算法的原理、实现代码和测试结果。
13 0
数据结构与算法学习十一:冒泡排序、选择排序、插入排序
|
24天前
|
搜索推荐 算法
【排序算法(一)】——插入排序,选择排序 —> 深层解析
【排序算法(一)】——插入排序,选择排序 —> 深层解析
|
4月前
|
算法 搜索推荐 C#
|
5月前
|
机器学习/深度学习 算法 搜索推荐
数据结构算法--2 冒泡排序,选择排序,插入排序
**基础排序算法包括冒泡排序、选择排序和插入排序。冒泡排序通过相邻元素比较交换,逐步将最大值“冒”到末尾,平均时间复杂度为O(n^2)。选择排序每次找到剩余部分的最小值与未排序部分的第一个元素交换,同样具有O(n^2)的时间复杂度。插入排序则类似玩牌,将新元素插入到已排序部分的正确位置,也是O(n^2)复杂度。这些算法适用于小规模或部分有序的数据。**
|
5月前
|
算法 搜索推荐
数据结构与算法-插入排序
数据结构与算法-插入排序
31 2
|
5月前
|
算法 搜索推荐 数据可视化
【漫画算法】插入排序:插入宝石的传说
【漫画算法】插入排序:插入宝石的传说
|
5月前
|
人工智能 搜索推荐 JavaScript
心得经验总结:排序算法:插入排序法(直接插入法和希尔排序法)
心得经验总结:排序算法:插入排序法(直接插入法和希尔排序法)
32 0
|
5月前
|
机器学习/深度学习 搜索推荐 算法
【C/排序算法】:直接插入排序和希尔排序
【C/排序算法】:直接插入排序和希尔排序
42 0
|
5月前
|
搜索推荐 算法
排序算法之插入排序
排序算法之插入排序
36 0
|
5月前
|
搜索推荐
排序算法---插入排序-----详解&&代码
排序算法---插入排序-----详解&&代码