博客
关于我
SWUST OJ 1099: 希尔排序算法实现
阅读量:653 次
发布时间:2019-03-15

本文共 691 字,大约阅读时间需要 2 分钟。

希尔排序算法实现

题目描述

编程实现希尔排序算法,按照非递减排序,测试数据为整数。

输入

第一行是待排序数据元素的个数n;

第二行是待排序的数据元素。

输出

一趟希尔排序后的结果。

样例输入

10

50 36 41 19 23 4 20 18 12 22

样例输出

4 20 18 12 22 50 36 41 19 23

思路

希尔排序是一种插入排序的方法,实际上是一种分组插入的方法。先定一个小于n的整数gap1作为第一个增量,把表的全部记录分成gap1个组,所有距离为gap1的倍数的记录放在同一个组中,在各组内进行直接插入排序;然后,取第二个增量gap2(<d1),重复上述的分组和排序,直至所取的增量gapt=1(gapt<gapt-1<…<gap2<gap1),即所有记录放在同一组中进行直接插入排序为止。

这里给出一个希尔排序的图片:

【实例】运用希尔排序将10个数9 1 2 5 7 4 8 6 3 5进行递增排序。

include <stdio.h>

int main(){

int n, data[1000], gap, temp, i;scanf("%d",&n);for(i=0; i

}

上述代码仅为参考,欢迎互联网的广大朋友们提出指正。

希尔排序的实现步骤

增量gap置初值,寻找序列长度n,令gap=n/2;

while循环直到gap≤0结束(因为是第一趟所以这步可以不用管)

① 根据条件进行插入排序(递增小在前大在后,递减则反之。)

② 减小增量(因为是第一趟所以这步可以不用管)

输出数据

注:以上代码仅供参考,实际实现时需根据具体需求调整参数。

转载地址:http://wimlz.baihongyu.com/

你可能感兴趣的文章
Openlayers中使用Cluster实现点位元素重合时动态聚合与取消聚合
查看>>
Openlayers中使用Cluster实现缩放地图时图层聚合与取消聚合
查看>>
Openlayers中使用Image的rotation实现车辆定位导航带转角(判断车辆图片旋转角度)
查看>>
Openlayers中使用Overlay实现点击要素弹窗并且弹窗随之移动
查看>>
Vmware系列&虚拟机系列【仅供参考】:使用vCenter Auto Deploy制作ESXI系统封装(适合高版本vSphere)
查看>>
Openlayers中加载GeoJson文件显示地图
查看>>
Openlayers中加载Geoserver切割的EPSG:900913离线瓦片图层组
查看>>
Openlayers中加载Geoserver切割的EPSG:900913离线瓦片地图并显示
查看>>
Openlayers中多图层遮挡时调整图层上下顺序
查看>>
Openlayers中实现地图上打点并显示图标和文字
查看>>
Openlayers中实现地图上添加一条红色直线
查看>>
Openlayers中将某个feature置于最上层
查看>>
Openlayers中点击地图获取坐标并输出
查看>>
Openlayers中设置定时绘制和清理直线图层
查看>>
Openlayers入门教程 --- 万字长篇
查看>>
Openlayers各组件默认的css样式
查看>>
Openlayers图文版实战,vue项目从0到1做基础配置
查看>>
VM16+ubuntu20.04+win10如何固定虚拟机的ip (固定IP)
查看>>
OpenLayers学习一:地图加载(以类为接口)
查看>>
OpenLayers学习三:地图旋转及地图跳转到某一点的方式(以类为接口)
查看>>