博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java排序算法(三):直接插入排序
阅读量:5293 次
发布时间:2019-06-14

本文共 1076 字,大约阅读时间需要 3 分钟。

[基本思想]

关键:在前面已经排好序的序列中找到合适的插入位置

步骤:

1. 从第一个元素開始,该元素能够觉得已经排好序。

2. 取出下一个元素。在已经排好序的元素序列中从后往前扫描进行比較。

3. 假设该元素(已排序) 大于新元素,则将该元素移到下一位置。

4. 反复步骤3,直到找到已排序的元素小于或者等于新元素的位置。

5. 将新元素插入到该位置后面。

6. 反复步骤2~5

[Java实现]

public class InsertSort {	public static void main(String[] args) {		int[] arr = { 6, 5, 3, 1, 8, 7, 2, 4 };		System.out.println("排序之前:");		for (int i = 0; i < arr.length; i++) {			System.out.print(arr[i] + " ");		}		// 直接插入排序		insertSort(arr);		System.out.println();		System.out.println("排序之后:");		for (int i = 0; i < arr.length; i++) {			System.out.print(arr[i] + " ");		}	}	/**	 * 直接插入排序	 */	private static void insertSort(int[] arr) {		int j; // 已排序列表下标		int t; // 待排序元素		for (int i = 1; i < arr.length; i++) {			if (arr[i] < arr[i - 1]) { 				t = arr[i]; // 赋值给待排序元素				for (j = i - 1; j >= 0 && arr[j] > t; j--) {					arr[j + 1] = arr[j]; // 从后往前遍历已排序列表,逐个和待排序元素比較,假设已排序元素较大,则将它后移				}				arr[j + 1] = t; // 将待排序元素插入到正确的位置			}		}	}}

点评:设置变量t非常重要,它记住了待插入的元素的值,元素移动的时候被覆盖了也没关系。

[算法特点]

时间复杂度:O(n^2)

直接插入排序法比冒泡和简单选择排序性能要好一些。

转载于:https://www.cnblogs.com/yfceshi/p/6816420.html

你可能感兴趣的文章
程序员的“机械同感”
查看>>
在16aspx.com上下了一个简单商品房销售系统源码,怎么修改它的默认登录名和密码...
查看>>
c++回调函数
查看>>
linux下Rtree的安装
查看>>
【Java】 剑指offer(53-2) 0到n-1中缺失的数字
查看>>
Delphi中ListView类的用法
查看>>
bzoj3110: [Zjoi2013]K大数查询 【树套树,标记永久化】
查看>>
[原创]Java 的传值小例子
查看>>
博客第一弹—聊聊HTML的那些事
查看>>
Mysql安装方法及安装问题解决
查看>>
Java动态代理的两种实现方式:
查看>>
PHP trait
查看>>
python 多线程并发threading & 任务队列Queue
查看>>
1_fbauto
查看>>
IO体系、集合体系、多线程、jdbc
查看>>
关于时间:UTC/GMT/xST/ xDT
查看>>
[51Nod1089] 最长回文子串 V2(Manacher算法)
查看>>
Asp.Net生命周期系列六
查看>>
php引用 =& 详解
查看>>
Codeforces 914D Bash and a Tough Math Puzzle (ZKW线段树)
查看>>