希尔排序Shell Sort是基于插入排序的一种改进,同样分成两部分,

第一部分,希尔排序介绍

第二部分,如何选取关键字,选取关键字是希尔排序的关键

第一块希尔排序介绍

准备待排数组[6 2 4 1 5 9]

首先需要选取关键字,例如关键是3和1(第一步分成三组,第二步分成一组),那么待排数组分成了以下三个虚拟组:

[6 1]一组

[2 5]二组

[4 9]三组

看仔细啊,不是临近的两个数字分组,而是3(分成了三组)的倍数的数字分成了一组,

就是每隔3个数取一个,每隔三个再取一个,这样取出来的数字放到一组,

把它们当成一组,但不实际分组,只是当成一组来看,所以上边的"组"实际上并不存在,只是为了说明分组关系

对以上三组分别进行插入排序变成下边这样

[1 6] [2 5] [4 9]

具体过程:

[6 1]6和1交换变成[1 6]

[2 5]2与5不动还是[2 5]

[4 9]4与9不动还是[4 9]

第一趟排序状态演示:

待排数组:[6 2 4 1 5 9]

排后数组:[1 2 4 6 5 9]

第二趟关键字取的是1,即每隔一个取一个组成新数组,实际上就是只有一组啦,隔一取一就全部取出来了嘛

此时待排数组为:[1 2 4 6 5 9]

直接对它进行插入排序

还记得插入排序怎么排不?复习一下

[1 2 4]都不用动,过程省略,到5的时候,将5取出,在前边的有序数组里找到适合它的位置插入,就是4后边,6前边

后边的也不用改,所以排序完毕

顺序输出结果:[1 2 4 5 6 9]

第二块希尔排序的关键是如何取关键字,因为其它内容与插入排序一样

那么如何选取关键字呢?就是分成三组,一组,这个分组的依据是什么呢?为什么不是二组,六组或者其它组嘞?

好的增量序列的共同特征:

① 最后一个增量必须为1

② 应该尽量避免序列中的值(尤其是相邻的值)互为倍数的情况

以下C#代码实现仅供参考

        static void shell_sort(int[] unsorted, int len)
{
int group, i, j, temp;
for (group = len / 2; group > 0; group /= 2)
{
for (i = group; i < len; i++)
{
for (j = i - group; j >= 0; j -= group)
{
if (unsorted[j] > unsorted[j + group])
{
temp = unsorted[j];
unsorted[j] = unsorted[j + group];
unsorted[j + group] = temp;
}
}
}
}
} static void Main(string[] args)
{
int[] x = { 6, 2, 4, 1, 5, 9 };
shell_sort(x, x.Length);
foreach (var item in x)
{
Console.WriteLine(item);
}
Console.ReadLine();
}

最新文章

  1. JSON-RPC 2.0 规范中文文档
  2. 【NuGet】搭建自己团队或公司的NuGet
  3. bat基础命令
  4. HDU 5995 Kblack loves flag ---BestCoder Round #90
  5. html-php深入理解
  6. MvvmCross for WPF 支持子窗体显示、关闭、传参
  7. android Timer and TImerTask
  8. HelloX操作系统网络功能简介及使用和开发指南
  9. 关于在Eclipse里面启动了服务,但是localhost:8080无法访问的问题:
  10. iOS 应用性能测试的相关方法、工具及技巧
  11. ParentWindow属性及其一系列函数的作用——适合于那些不需要父控件管理内存释放的子控件
  12. 4 Java学习之 反射Reflection
  13. [转] Python正则表达式指南
  14. IOS 特定于设备的开发:使用加速能力“向上定位”
  15. 对Kalman(卡尔曼)滤波器的理解
  16. CI Weekly #13 | 用更 Geek 的方式配置你的 CI 工作流
  17. Sagit.Framework For IOS 开发框架入门开发教程2:一行代码实现引导页
  18. P2515 [HAOI2010]软件安装
  19. Oracle EBS ERP中月结年结的流程总结
  20. Elasticsearch笔记八之脑裂

热门文章

  1. Oil Deposits(DFS连通图)
  2. 感谢信——Alpha版
  3. zookeeper启动配置
  4. win7 x64+iis7.5 配置错误:CS0016: 未能写入输出文件&ldquo;c:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporary ASP.NET Files\root\7cb4f3
  5. 3dContactPointAnnotationTool开发日志(七)
  6. Swagger Authorization:bearer &lt;token&gt;
  7. hibernate.cfg.xml的详细解释
  8. C的强制转换和C++的强制转换(转)
  9. 导入导出SQL数据库
  10. ASP.NET MVC下使用文件上传和IIS7下的默认设置限制了上传大小的方法