八大排序算法之-直接插入排序 java代码

来源:互联网 发布:颈椎牵引 知乎 编辑:程序博客网 时间:2024/05/24 07:42
import java.util.Arrays;/** * Created by Administrator on 2017/8/2. */public class directInsertSort_insert {    public static void main(String args[]) {        int[] arr = { 6, 9, 1, 3, 1, 2, 2, 5, 6, 1, 3, 5, 9, 7, 2, 5, 6, 1, 9 };        //[1, 1, 1, 1, 2, 2, 2, 3, 3, 5, 5, 5, 6, 6, 6, 7, 9, 9, 9]        insertSort(arr,0,arr.length-1);        System.out.println(Arrays.toString(arr));    }    /*算法思想:    * 1.假设第一个元素是排序好的, 依次将后面的元素插入到排序好的元素中*/    /*时间复杂度:O(n^2)    空间复杂度:O(1)    稳定性:稳定    * */    private static void insertSort(int[] arr, int start, int end) {        for (int i = 1; i<=end; i++) {            while (i-1>=0 && arr[i]<arr[i-1]) {                swap(arr,i,i-1);                i--;            }        }    }    private static void swap(int[] arr, int i, int i1) {        int tmp = arr[i];        arr[i] = arr[i1];        arr[i1] = tmp;    }}

原创粉丝点击