对插入排序的改进计算机等级考试

文章作者 100test 发表时间 2010:01:01 13:02:51
来源 100Test.Com百考试题网


  插入排序的性能大家都了解了,时间复杂度是O(n2),有没有办法提升他的效率呢? 这里有一个方法,在宏观上可以将插入排序的时间复杂度降低到nlogn。
  其思想如下,插入排序中每次将本次取到的数据插入到已排序序列的时候,都会将有序序列中大于这个数据的元素依次向后移动一个单元,这个过程的时间复杂度就是n,有没有办法简化这个过程呢,其实有一种方法:因为待插入的序列是有序的,所以我们可以使用一个二分查询定位出新元素要插入的位置(插入到这个位置后,这个序列依然保持有序,这个操作的时间复杂度为logn),知道这个位置之后就好办了,我们可以将这个位置后面的序列整块的向后移动一个位置,这个操作称为memmove—整块的移动内存单元(这样,移动元素的时间复杂度就变成1了),因为这时候数组的位置已经腾出来了,我们可以将新的元素插入到指定位置(这个操作复杂度为1)。
  因此,整个插入的操作时间复杂度为logn 2,常数项可以忽略,因此复杂度为logn,因为整个排序需要n次插入操作,那么整个算法的复杂度就为nlogn
  从宏观上看,这个算法的时间复杂度为nlogn,当然具体的性能还要看memmove这个操作的效率。
  一个C语言的实现如下
  1 #include 

相关文章


“指向const对象的指针”和“const指针”计算机等级考试
CPPTemplates之template关键字的用法技巧计算机等级考试
CPPTemplates之类模板的继承计算机等级考试
BerkeleyDB数据访问算法说明计算机等级考试
对插入排序的改进计算机等级考试
C 模板类继承中诡异的作用域问题计算机等级考试
c 中头文件重复定义的问题计算机等级考试
CPPTemplates之仿函数计算机等级考试
计算机二级C 辅导:打印自身的C++代码计算机等级考试
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛