zoukankan      html  css  js  c++  java
  • 算法学习记录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 }
  • 相关阅读:
    Luogu 1514 引水入城
    HDU 2196 Computer
    CF460C Present
    初等数论整理
    2019UMS培训day6解题报告
    2019UMS培训day5解题报告
    2019UMS培训day3解题报告
    Luogu 1731 生日蛋糕
    JavaWeb之ServletContext域对象
    c3p0连接池
  • 原文地址:https://www.cnblogs.com/abcwt112/p/6520268.html
Copyright © 2011-2022 走看看