c++对插入排序的改进

来源:计算机等级考试    发布时间:2012-08-29    计算机等级考试视频    评论

  其思想如下,插入排序中每次将本次取到的数据插入到已排序序列的时候,都会将有序序列中大于这个数据的元素依次向后移动一个单元,这个过程的时间复杂度就是n,有没有办法简化这个过程呢,其实有一种方法:因为待插入的序列是有序的,所以我们可以使用一个二分查询定位出新元素要插入的位置(插入到这个位置后,这个序列依然保持有序,这个操作的时间复杂度为logn),知道这个位置之后就好办了,我们可以将这个位置后面的序列整块的向后移动一个位置,这个操作称为memmove—整块的移动内存单元(这样,移动元素的时间复杂度就变成1了),因为这时候数组的位置已经腾出来了,我们可以将新的元素插入到指定位置(这个操作复杂度为1)。
  因此,整个插入的操作时间复杂度为logn+2,常数项可以忽略,因此复杂度为logn,因为整个排序需要n次插入操作,那么整个算法的复杂度就为nlogn
  从宏观上看,这个算法的时间复杂度为nlogn,当然具体的性能还要看memmove这个操作的效率。
  一个C语言的实现如下
  1 #include <ctype.h>
  2 #include <string.h>
  3
  4  int binary_index(int *arr,int p,int q,int key){
  5    
  6     int mid;
  7     while(p <= q){
  8         mid = (q + p) / 2;
  9         if(arr[mid] < key){
  10             p = mid + 1;
  11         }else if(arr[mid] > key){
  12             q = mid - 1;
  13         }else{
  14             return mid;
  15         }
  16     }
  17     return p;
  18
  19 }
  20 void insertion_sort_improved(int *arr,int len){
  21     int i,j,key,k,move_len;       
  22     for(i = 1;i < len;i++){
  23         j = i - 1;
  24         key = arr[i];
  25         k = binary_index(arr,0,j,key);
  26         move_len = j - k + 1;           
  27         memmove(arr + (k + 1),arr  + k,move_len * sizeof(int));
  28         arr[k] = key;
  29
  30     }
  31
  32 }

  编辑特别推荐:

  C++编程之编译器

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答