排序算法是我们在编程过程中经常遇到的算法,所以,掌握常用的几种排序算法是非常必要的。今天我们看一下插入排序。
所谓插入排序,就是将一个元素,按照相应的排列规则,插入到一个已经排好序的数组中,从而使这个新的数组也是排好序的。
我们看一下插入排序的基本流程,如下面所示:
初始数组: [3] 8 5 6 7 4 9 2 1
第一次插入: [3 8] 5 6 7 4 9 2 1
第二次插入: [3 5 8] 6 7 4 9 2 1
第三次插入: [3 5 6 8] 7 4 9 2 1
第四次插入: [3 5 6 7 8] 4 9 2 1
第五次插入: [3 4 5 6 7 8] 9 2 1
第六次插入: [3 4 5 6 7 8 9] 2 1
第七次插入: [2 3 4 5 6 7 8 9] 1
第八次插入: [1 2 3 4 5 6 7 8 9]
至此,排序过程完毕,数组已经成为一个排好序的数组。
从上面的流程,大家可以看出,插入排序就是将前面的一个或者几个元素看成是一个排好序的数组,然后用后面的一个元素跟排好序数组中的元素进行比较,从而将元素插入到一个合适的位置。直到将所有的元素都插入排好序的数组中,排序过程完成。
插入排序的java实现:
public class SortUtil { /** * <p> * 方法名:插入排序 * 方法说明:利用插入排序法,对数组进行排序,并返回排好序的数组。 * </p> * @param array 待排序的数组 * @return 排好序的数组 */ public static <T extends Comparable<T>> T[] insertionSort(T[] array) { for (int i = 1; i < array.length; i++) { T key = array[i]; int location = i; for (int j = i - 1; j >= 0; j--) { if (key.compareTo(array[j]) < 0) { array[j + 1] = array[j]; location = j; } else { break; } } array[location] = key; } return array; } }
测试代码:
public static void main(String[] args) { Integer[] array1 = {3,8,5,6,7,4,9,2,1}; Integer[] array2 = {1,2,3,4,5,6,7,8,9}; Integer[] array3 = {9,8,7,6,5,4,3,2,1}; System.out.println(Arrays.toString(SortUtil.insertionSort(array1))); System.out.println(Arrays.toString(SortUtil.insertionSort(array2))); System.out.println(Arrays.toString(SortUtil.insertionSort(array3))); }
测试结果:
[1, 2, 3, 4, 5, 6, 7, 8, 9] [1, 2, 3, 4, 5, 6, 7, 8, 9] [1, 2, 3, 4, 5, 6, 7, 8, 9]
相关推荐
实现以下常用的内部排序算法并进行性能比较:"直接插入排序"," 折半插入排序"," 2—路插入排序"," 表插入排序"," 希尔排序"," 起泡排序"," 快速排序"," 简单选择排序"," 树形选择排序"," 堆排序"," 归并排序"," 链式...
21、折半插入排序 22、21、折半插入排序 22、冒泡排序 21、折半插入排序 22、冒泡排序 23、快速排序 21、折半插入排序 22、冒泡排序 23、快速排序 24、简单选择排序 21、折半插入排序 22、冒泡排序 23、快速排序 24...
(1) 完成5种常用内部排序算法的演示,5种排序算法为:快速排序,直接插入排序,选择排序,堆排序,希尔排序; (2) 待排序元素为整数,排序序列存储在数据文件中,要求排序元素不少于30个; (3) 演示程序开始,...
此案例难度系数4,属于Scratch高级编程,插入排序相对而言比选择排序和冒泡排序理解起来要难一点,但是还是相对简单的排序,尤其是对少量元素排序的时候,效率较高;综合考查说话、随机数、无限循环(条件循环)、...
全面的排序算法实现,包括插入排序、合并排序、堆排序、快速排序。 堆排序:HeapSort 讲解详见http://blog.csdn.net/fly_yr/article/details/8550701 插入排序:InSertion_Sort 讲解详见...
用函数实现直接插入排序,并输出每趟排序的结果. Input 第一行:键盘输入待排序关键的个数n 第二行:输入n个待排序关键字,用空格分隔数据 Output 每行输出一趟排序结果,数据之间用一个空格分隔 Sample Input 10 ...
数据结构(c语言版)严蔚敏 吴伟民编著 中直接插入排序、折半排序、shell排序、冒泡排序、快速排序、选择排序、堆排序的实现、归并排序,使用c语言实现
选择排序和冒泡排序想必大家都很熟悉,但插入排序一般新手却很难理解,插入排序的Java源代码
插入排序 C语言 Insert sort
直接插入排序 选择排序 堆排序 归并排序 快速排序 冒泡排序等七种排序方法
选择排序、插入排序、冒泡排序以及快速排序和归并排序的C语言实现,绝对可用
用函数实现折半插入排序,并输出每趟排序的结果. Input 第一行:键盘输入待排序关键的个数n 第二行:输入n个待排序关键字,用空格分隔数据 Output 每行输出一趟排序结果,数据之间用一个空格分隔 Sample Input 10 5...
插入排序,选择排序,基数排序,冒泡排序的C++实现
mips实现插入排序,带详细注释,spim上可运行
经典的快速排序算法,使用分治法思想,使用C++的插入排序,使用算法课程的基础编程。
简单插入排序思想,将一个无序的数组,想象成由两部分组成,一部分为有序列,一部分为无序列,初始时,有序列为数组第一个元素,无序列为第一个元素之后的元素组成。每次从无序列中取第一个数插入到有序列中,有序列...
随机生成小于5000的数 根据操作通过不同的方法排序 泡泡排序 直接插入排序 折半插入排序 希尔排序 直接选择排序 统计时间 比较次数和交换次数 保存为txt文件
合并排序,插入排序,希尔排序,快速排序,冒泡排序,桶排序的C语言实现,原创。
Python 插入排序算法详解 Python 的插入排序算法是一种简单而高效的排序算法,旨在对小规模数据进行排序。插入排序算法的主要思想是,每次从未排序的序列中拿出一个元素,将其插入到已经排好序的序列中合适的位置,...
对半插入排序的思想是:在插入 Ri时(这时R1,R2,…,Ri–1已经排序),取Ki/2 与Ki 进行比较,如果Ki,则Ri只能插在R1与Ri/2之间,故可以在R1与Ri/2–1 之间递归上述过程,否则可以在Ri/2+1与Ri–1之间递归上述...