编程码拉松希尔排序

Posted 丽水码猿教育

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了编程码拉松希尔排序相关的知识,希望对你有一定的参考价值。

【编程码拉松】希尔排序

【编程码拉松】希尔排序

希尔排序的优劣

不需要大量的辅助空间,和归并排序一样容易实现。希尔排序是基于插入排序的一种算法, 在此算法基础之上增加了一个新的特性,提高了效率。


希尔排序没有快速排序算法快 O(n(logn)),因此中等大小规模表现良好,对规模非常大的数据排序不是最优选择。并且希尔排序非常容易实现,算法代码短而简单。此外,希尔算法在最坏的情况下和平均情况下执行效率相差不是很多,与此同时快速排序在最坏的情况下执行的效率会非常差。


专家们提倡,几乎任何排序工作在开始时都可以用希尔排序,若在实际使用中证明它不够快,再改成快速排序这样更高级的排序算法. 本质上讲,希尔排序算法是直接插入排序算法的一种改进,减少了其复制的次数,速度要快很多。 


原因是,当n值很大时数据项每一趟排序需要移动的个数很少,但数据项的距离很长。当n值减小时每一趟需要移动的数据增多,此时已经接近于它们排序后的最终位置。正是这两种情况的结合才使希尔排序效率比插入排序高很多。Shell算法的性能与所选取的分组长度序列有很大关系。只对特定的待排序记录序列,可以准确地估算关键词的比较次数和对象移动次数。


想要弄清关键词比较次数和记录移动次数与增量选择之间的关系,并给出完整的数学分析,今仍然是数学难题

【编程码拉松】希尔排序

【编程码拉松】希尔排序

【编程码拉松】希尔排序

【编程码拉松】希尔排序

【编程码拉松】希尔排序

【编程码拉松】希尔排序

联系人:叶老师

联系方式:13082893881(微信同号)





【编程码拉松】希尔排序
【编程码拉松】希尔排序

在码猿Scratch创意编程课中

孩子们利用计算机作为工具

研究各种领域(艺术、数学、物理、自然、社会等等)的问题,视角极其广泛

电脑编程能充分调动少儿创造力的探索性实践活动

是真正的“脑力冲浪”!

从小培养孩子的创造能力,探索科技的情操;

激发青少年的创意想象与逻辑思维;

培养他专心致志做事情的好习惯。

点击“阅读原文”可直接报名参加体验班


以上是关于编程码拉松希尔排序的主要内容,如果未能解决你的问题,请参考以下文章

排序算法之希尔排序

插入排序及希尔排序

八十五再探希尔排序,桶排序,计数排序和基数排序

十大经典排序之:插入排序 |希尔排序

python实现希尔排序(已编程实现)

常考排序算法总结(插入排序,希尔排序,快速排序,归并排序,计数排序)