1 问题描述
给定一组数据,使用插入排序得到这组数据的非降序排列。
2 解决方案
2.1 插入排序原理简介
引用自百度百科:
有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序,这个时候就要用到一种新的排序方法——,插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。
插入排序的基本思想是:每步将一个待排序的纪录,按其关键码值的大小插入前面已经排序的文件中适当位置上,直到全部插入完为止。
2.2 具体编码
package com.liuzhen.chapterFour;public class InsertionSort { public static void getInsertionSort(int[] A){ int len = A.length; System.out.print("未排序时序列: "); for(int p = 0;p < len;p++) System.out.print(A[p]+"\t"); System.out.println(); for(int i = 1;i < len;i++){ int temp = A[i]; int j = i - 1; while(j >= 0 && A[j] > temp){ //每次循环结束,完成一个元素的插入排序 A[j+1] = A[j]; j = j - 1; A[j+1] = temp; } System.out.print("第"+i+"次排序序列:"); for(int p = 0;p < len;p++) System.out.print(A[p]+"\t"); System.out.println(); } } public static void main(String[] args){ int[] A = {89 , 45 , 68 , 90 , 29 , 34 , 17}; getInsertionSort(A); }}
运行结果:
未排序时序列: 89 45 68 90 29 34 17 第1次排序序列:45 89 68 90 29 34 17 第2次排序序列:45 68 89 90 29 34 17 第3次排序序列:45 68 89 90 29 34 17 第4次排序序列:29 45 68 89 90 34 17 第5次排序序列:29 34 45 68 89 90 17 第6次排序序列:17 29 34 45 68 89 90