当前位置: 首页 > 编程笔记 >

Java实现直接插入排序和折半插入排序算法示例

颛孙炜
2023-03-14
本文向大家介绍Java实现直接插入排序和折半插入排序算法示例,包括了Java实现直接插入排序和折半插入排序算法示例的使用技巧和注意事项,需要的朋友参考一下

直接插入排序​
1 排序思想:

将待排序的记录Ri插入到已经排好序的记录R1,R2,……,R(N-1)中。

对于一个随机序列而言,就是从第二个元素开始,依次将这个元素插入到它之前的元素中的相应位置。它之前的元素已经排好序。

第1次排序:将第2个元素插入到前边的有序列表(此时前边只有一个html" target="_blank">元素,当然是有序的),之后,这个序列的前2个元素就是有序的了。
第2次排序:将第3个元素插入到前边长度为2的有序列表,使得前2个元素是有序的。
以此类推,直到将第N个元素插入到前面长度为(N-1)的有序列表中。

2 算法实现:

// 直接插入排序
void straight_insert_sort(int num[], int len){
 int i,j,key;
 for(j=1;j<len;j++){
  key=num[j];
  i=j-1;
  while(i>=0&&num[i]>key){
   num[i+1]=num[i];
   i--;
  }
  num[i+1]=key;
 }
}

3 性能分析:

3.1 空间复杂度:如上代码,使用了一个辅助单元key,空间复杂度为O(1)

3.2 时间复杂度:

3.2.1 最好情况:待排序记录已经是有序的,则一趟排序,关键字比较1次,记录移动2次。则整个过程

比较次数为

记录移动次数为

时间复杂度O(n)

3.2.2 最坏情况:待排序记录已经是逆序的,则一趟排序,关键字比较次数i次(从i-1到0),记录移动(i+2)次。整个过程

比较次数为

记录移动次数为

时间复杂度O(n^2)

3.2.3 平均时间复杂度:O(n^2)

3.3 稳定性:稳定

折半插入排序
1 排序思想:

直接排序的基础上,将待排序的记录Ri插入到已经排好序的记录R1,R2,……,R(N-1)中,由于记录R1,R2,……,R(N-1)已经排好序,所以在查找插入位置时可采用“折半查找”。

2 算法实现:

// 折半插入排序
void binary_insert_sort(int num[], int len){
 int i,j,key,low,high,mid;
 for(i=1;i<len;i++){
  key=num[i];
  low=0;
  high=i-1;
  mid=(low+high)/2;
  // 寻找插入点,最终插入点在low
  while(low<=high){
   if(key<num[mid])
    high=mid-1;
   else 
    low=mid+1;
   mid=(low+high)/2;
  }
  // 移动记录
  for(j=i;j>low;j--){
   num[j]=num[j-1];
  }
  // 插入记录
  num[low]=key;
 }
}

3 性能分析:

3.1 空间复杂度:如上代码,使用了一个辅助单元key,空间复杂度为O(1)

3.2 时间复杂度:虽然折半查找减少了记录比较次数,但没有减少移动次数,因此时间复杂度同直接查找算法。

3.2.1 最好情况:时间复杂度O(n)

3.2.2 最坏情况:时间复杂度O(n^2)

3.2.3 平均时间复杂度:O(n^2)

3.3 稳定性:稳定

 类似资料:
  • 本文向大家介绍JS折半插入排序算法实例,包括了JS折半插入排序算法实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JS折半插入排序算法。分享给大家供大家参考,具体如下: 希望本文所述对大家JavaScript程序设计有所帮助。

  • 直接插入排序的基本思想是:将 n 个有序数存放在数组 a 中,要插入的数为 x,首先确定 x 插在数组中的位置 p,然后将 p 之后的元素都向后移一个位置,空出 a(p),将 x 放入 a(p),这样可实现插入 x 后仍然有序。 例 1 本例子通过直接插入的方法对上述例子中的 number 数组进行排序。创建一个 Test27 类文件,在 main() 方法中开始编码,具体实现代码如下: 在上述代

  • 本文向大家介绍java实现折半排序算法,包括了java实现折半排序算法的使用技巧和注意事项,需要的朋友参考一下 折半插入排序(binary insertion sort)是对插入排序算法的一种改进,由于排序算法过程中,就是不断的依次将元素插入前面已排好序的序列中。由于前半部分为已排好序的数列,这样我们不用按顺序依次寻找插入点,可以采用折半查找的方法来加快寻找插入点的速度。 折半排序算法示意图: 以

  • 主要内容:插入排序算法的具体实现插入排序算法可以对指定序列完成升序(从小到大)或者降序(从大到小)排序,对应的时间复杂度为 。 插入排序算法的实现思路是:初始状态下,将待排序序列中的第一个元素看作是有序的子序列。从第二个元素开始,在不破坏子序列有序的前提下,将后续的每个元素插入到子序列中的适当位置。 举个简单的例子,用插入排序算法对 {14, 33, 27, 10, 35, 19, 42, 44} 实现升序排序的过程如下: 1)

  • 本文向大家介绍ruby实现的插入排序和冒泡排序算法,包括了ruby实现的插入排序和冒泡排序算法的使用技巧和注意事项,需要的朋友参考一下 1、插入排序 2、冒泡排序

  • 直接插入排序是比较简单的排序算法,它主要是将我们要排序的序列分成两个部分,一个有序一个无序,然后将无序序列中的值依次插入到有序序列中。 这么讲如果不能理解,我们拿例子去讲,假如有序列8 7 2 1 5 9 3这么一个序列,如下表所示。我们要将这个序列进行升序排序,接下来演示插入排序的过程。 初始序列 8 7 2 1 5 9 3 第一次排序 从前往后排,将8作为我们的有序序列的第一个值,而8后面的值