网站首页 > 精选教程 正文
插入排序(Insertion Sort)是一种简单直观的排序算法,其工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
说明:
在插入排序中,我们维护两个指针,一个在已排序的序列中,通常从后向前移动(这是实现的一种方式,也可以从前向后移动),另一个在未排序的序列中,向前移动。当未排序的元素找到在已排序序列中的位置时,它就被插入。
例如,对于数组 [5, 3, 4, 7, 2, 8, 6, 9, 1],插入排序的过程如下:
- 我们首先把3插入到已排序的序列 [5] 中,得到 [3, 5]。
- 然后我们把4插入到已排序的序列 [3, 5] 中,得到 [3, 4, 5]。
- 接着我们把7插入到已排序的序列 [3, 4, 5] 中,得到 [3, 4, 5, 7]。
- 然后我们把2插入到已排序的序列 [3, 4, 5, 7] 中,得到 [2, 3, 4, 5, 7]。
- 最后我们把8和9插入到已排序的序列 [2, 3, 4, 5, 7] 中,得到 [2, 3, 4, 5, 7, 8, 9]。
时间复杂度:
- 最好情况:O(n),当输入已经部分排序时(这是由于元素不需要移动或移动很短距离)
- 最坏和平均情况:O(n^2)
- 空间复杂度:O(1)(因为只使用了常量级别的额外空间)
用途:
插入排序在以下情况中特别有用:
- 数据量较小,或者数据已经部分排序时。当数据量较大且无序时,插入排序的效率较低。
- 对于部分有序的数据,插入排序的效率较高。
- 当数据是链表或者内存使用效率非常重要的时候。
JAVA代码实例:
import java.util.Arrays;
public class InsertionSort {
public static int[] sort(int arr[]) {
int n = arr.length;
for (int i = 1; i < n; ++i) {
int key = arr[i];
int j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j]; // 如果当前元素(key)比前一个元素小,就将前一个元素向后移动一位
j = j - 1;
}
arr[j + 1] = key; // 将key插入到正确的位置
}
return arr;
}
public static void main(String args[]) {
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int[] result = sort(arr);
System.out.println("排序结果为:" + Arrays.toString(result));
// 排序结果为:[11, 12, 22, 25, 34, 64, 90]
}
}
这段代码是插入排序的基本实现。sort方法遍历整个数组,对于每个元素,它都在已排序的序列中找到正确的位置并插入。如果当前元素小于已排序序列中的某个元素,就将该元素向后移动一位,直到找到当前元素的正确位置。
- 上一篇: JAVA数据结构和算法-简单排序之插入排序
- 下一篇: 算法排序----插入排序法(算法排序)
猜你喜欢
- 2024-11-17 基础算法之「插入排序」(c语言排序算法直接插入法)
- 2024-11-17 程序猿小白进阶之路,一天学习一个算法:插入排序
- 2024-11-17 常用排序算法之插入排序(常用排序算法之插入排序规则)
- 2024-11-17 看动图学算法(三):插入排序算法原理和Java讲解
- 2024-11-17 Java程序员面试时写不出排序算法?看这篇就够了
- 2024-11-17 Python 实现经典算法之插入排序(用python排序算法)
- 2024-11-17 掌握算法-排序-插入排序(掌握算法-排序-插入排序规则)
- 2024-11-17 排序之插入排序(直接插入排序算法)
- 2024-11-17 一文掌握Python 中的排序算法——插入排序
- 2024-11-17 在 Python 中实现插入排序(Insertion Sorting)
你 发表评论:
欢迎- 04-11Java面试“字符串三兄弟”String、StringBuilder、StringBuffer
- 04-11Java中你知道几种从字符串中找指定的字符的数量
- 04-11探秘Java面试中问的最多的String、StringBuffer、StringBuilder
- 04-11Python字符串详解与示例(python字符串的常见操作)
- 04-11java正则-取出指定字符串之间的内容
- 04-11String s1 = new String("abc");这句话创建了几个字符串对象?
- 04-11java判断字符串中是否包含某个字符
- 04-11关于java开发中正确的发牌逻辑编写规范
- 最近发表
-
- Java面试“字符串三兄弟”String、StringBuilder、StringBuffer
- Java中你知道几种从字符串中找指定的字符的数量
- 探秘Java面试中问的最多的String、StringBuffer、StringBuilder
- Python字符串详解与示例(python字符串的常见操作)
- java正则-取出指定字符串之间的内容
- String s1 = new String("abc");这句话创建了几个字符串对象?
- java判断字符串中是否包含某个字符
- 关于java开发中正确的发牌逻辑编写规范
- windows、linux如何后台运行jar(并且显示进程名)
- 腾讯大佬私人收藏,GitHub上最受欢迎的100个JAVA库,值得学习
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)