当前位置: 首页 > news >正文

排序——希尔排序

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、希尔排序
  • 二、希尔排序动态图
  • 三、希尔排序程序代码
  • 四、希尔排序习题
  • 总结


前言

  1. 希尔排序定义
  2. 希尔排序算法分析
  3. 希尔排序程序代码
  4. 希尔排序练习题

一、希尔排序

1.定义:先将待排序表分为若干个相同长度的子表(最后一个可不计),分别进行直接插入排序,当基本有序时,再对整体做一次直接插入排序,步骤:
(1)取一个步长d1 ,分为d1组,所有距离为d1倍数的放在一组
(2)各组中进行插入排序
(3)然后取步长d2,重复上述,直到取到步长为1,即所有记录已放在同一组中,再进行直接插入排序
(4)一般的,取d1=n/2 ,di+1=di/2向下取整,并且最后一个为1

二、希尔排序动态图

在这里插入图片描述

三、希尔排序程序代码

void ShellInsert(elementtype r[n+1],int k){dh=k;while(dh>=1){for(i=dh+1li<=n;i++){r[0]=r[I];j=i-dh;while(j>0&&r[j]>r[0]){r[j+dh]=r[j];j=j-dh;}r[j+dh]=r[0];}dh=dh/2;}
}

2.效率:空间为O(1),时间效率最坏情况下 O(n2)
3.稳定性:相同关键字会被划分为不同子表中,所以为不稳定算法
4.适用性:仅适用于顺序表

四、希尔排序习题

例题:
9、1、2、5、7、4、8、6、3、5
第一趟排序:4、1、2、3、5、9、8、6、5、7
第二趟排序:2、1、4、3、5、6、5、7、8、9
第三趟排序:1、2、3、4、5、5、6、7、8、9


总结

  1. 希尔排序定义
  2. 希尔排序算法分析
  3. 希尔排序程序代码
  4. 希尔排序练习题
http://www.lryc.cn/news/169283.html

相关文章:

  • 为什么文件夹里的文件看不到?了解原因及应对措施
  • KVM嵌套虚拟化实现
  • 驱动开发,IO模型,信号驱动IO实现过程
  • 左神高级进阶班3(TreeMap顺序表记录线性数据的使用, 滑动窗口的使用,前缀和记录结构, 可能性的舍弃)
  • Linux线程
  • C++ 太卷,转 Java?
  • 《Java并发编程实战》第2章-线程安全性
  • 二蛋赠书三期:《C#入门经典(第9版)》
  • Augmented Large Language Models with Parametric Knowledge Guiding
  • Docker启动Mysql容器并进行目录挂载
  • 力扣刷题(简单篇):两数之和、两数相加、无重复字符的最长子串
  • Spark的基础
  • 如何在idea中新建第一个java小程序
  • AOP全局异常处理
  • 一阶低通滤波器滞后补偿算法
  • JS中Symbol的介绍
  • 封装统一响应结果类和消息枚举类
  • 应广单片机实现红蓝双色爆闪灯
  • 深入了解OSI模型:计算机网络的七大层次
  • games101 作业2
  • 二叉树链式存储结构
  • Claude 使用指南 | 可与GPT-4媲美的语言模型
  • 【汇编】微处理器
  • 按键点亮led灯
  • Java常见面试题
  • 笔记1.5:计算机网络体系结构
  • 【Python】Python 连接字符串应优先使用 join 而不是 +
  • uniapp 小程序 父组件调用子组件方法
  • Vue-01:MVVM数据双向绑定与Vue的生命周期
  • 数据通信网络之OSPFv3基础