算法学习记录6 折半插入排序

理解

其实就是插入排序,只是插入排序对于当前元素要找到插入哪个位置的时候需要和之前的元素一个一个比较,比较耗时.

而折半插入排序利用了当前元素之前的数组元素已经全部排好顺序位置的特点,用二分法查找要插入到哪个位置.所以速度会快一些

 

实现

 1 package algorithm.sort;
 2 
 3 import java.util.Arrays;
 4 
 5 public class BinaryInsertSortTest1 {
 6     public static void main(String[] args) {
 7         int[] arr1 = { 4, 7, 5, 6, 1, 3, 8 };
 8         int[] arr2 = { 7, 6, 5, 4, 3, 2, 1 };
 9         int[] arr3 = { 5, 9, 3, 7, 8, 6, 1, 2, 4 };
10         int[] arr4 = { 13, 2, 5, 4, 88, 76, 68, 87, 55, 88, 88, 77, 67, 99, 100, 5, 53, 52, 51, 66 };
11         sort(arr1);
12         sort(arr2);
13         sort(arr3);
14         sort(arr4);
15         System.out.println(Arrays.toString(arr1));
16         System.out.println(Arrays.toString(arr2));
17         System.out.println(Arrays.toString(arr3));
18         System.out.println(Arrays.toString(arr4));
19     }
20 
21     public static void sort(int[] arr) {
22         for (int i = 1; i < arr.length; i++) {// 循环遍历数组,定第2个元素开始,只有1个元素的话不用排序
23             int value = arr[i];
24             int low = 0;
25             int mid = 0;
26             int high = i - 1;
27             while (low <= high) { // 2分法查找要插入的位置,终止条件是high=mid-1以后比low小.小于符号的满足条件的情况是high=low+1,mid=low,high=mid-1<low
28                 mid = (low + high) / 2;
29                 if (value > arr[mid]) { // 如果比mid大,下次查找的数组为mid的后半段
30                     low = mid + 1;
31                 } else { // 否则下次查找的数组为mid的前半段
32                     high = mid - 1;
33                 }
34             }
35             // value就应该放到low这个位置,所以把low之后的元素都向后移动一格
36             for (int j = i; j > low; j--) {
37                 arr[j] = arr[j - 1];
38             }
39             arr[low] = value;
40         }
41     }
42 }

 

转载于:https://www.cnblogs.com/abcwt112/p/6520268.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值