java-数组排序--插入排序

时间:2023-03-09 20:15:00
java-数组排序--插入排序

插入排序

想象着你的左手拿着一手好牌[1,1,1,2,6,6,6,9,9],此时你从桌面上又抽出一张牌[1],你将抽出的牌,从又往左,依次与左手的牌进行比较(只以数字进行对比),当抽出的牌第一次不再大于手中的牌,你将抽出的牌插入此牌的相邻右边,入[1,1,,,2,6,6,6,9,9],绿色为从右往左第一个抽出牌不再大的牌,红色为抽出的牌,这样你就回发现,虽然左手中的牌不断增加,但都将持续保持有序状态

插入排序同上方抽牌的例子相似,她将一个待排序数列分为左右两部分,并令左半部分为有序,右半部分为无序,每次从无序数列中取出一个数(无序部分最左端的一个数),并将其插入到有序数列中的合适位置(待排序数从右往左比较有序部分的元素,直到待排序数遇到第一个她不再大于的元素,此时待排序数将安置在此元素的右方),最开始,对于有序部分,其元素个数为0个,并在新元素的插入下不断增多,直到整个待排序数列有序

插入排序 - 方式一

方法将待排序数持续向左移动,直到待排序数不再大于前一个数

见图

java-数组排序--插入排序

上代码

     public static void insertSort(int[] arr) {

         for (int i = 0; i < arr.length; i++) {
for (int j = i; j > 0; j--) {
if(arr[j]<arr[j-1]) {
int tmp=arr[j];
arr[j]=arr[j-1];
arr[j-1]=tmp;
}
}
}
}

测试

    public static void main(String[] args) {

        Sort.insertSort(new int[] {6,10,6,8,6,8,12,15,9,6,7});

    }

java-数组排序--插入排序

插入排序 - 方式二

思想与上面的相同,只是方法避免了重复多次的相邻数据的交换,只在最后一步将待排序树插入到合适位置

上图

java-数组排序--插入排序

上代码

     public static void insertSort(int[] arr) {

         for (int i = 0; i < arr.length; i++) {
int j = i;
int tmp=arr[i];
for (; j > 0 && tmp<arr[j-1]; j--) {
arr[j]=arr[j-1];
}
arr[j]=tmp;
}
}

测试

    public static void main(String[] args) {

        Sort.insertSort(new int[] {6,10,6,8,6,8,12,15,9,6,7});

    }

java-数组排序--插入排序


如果有地方写的错误,或者有什么疑问与建议,欢迎大家提出来 愿与大家一同进步

相关文章