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

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

1099: 希尔排序算法实现

题目描述

编程实现希尔排序算法,按照非递减排序,测试数据为整数。
输入
第一行是待排序数据元素的个数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),即所有记录放在同一组中进行直接插入排序为止。
  • 这里给出一个希尔排序的视频:
    【B站】https://www.bilibili.com/video/BV1j84y1c78o
  • 这里再给出一个希尔排序的图片:
    【实例】运用希尔排序将10个数9 1 2 5 7 4 8 6 3 5进行递增排序。

在这里插入图片描述

(栗子转载自)

我对希尔排序的浅显理解是进行隔空比较,交换数值,每次所隔之空gap都是上一所隔之空gap的一半,下面是具体的实现步骤:

  1. 增量gap置初值,寻找序列长度n,令gap=n/2;
  2. while循环直到gap<=0结束(因为是第一趟所以这步可以不用管)
    ① 根据条件进行插入排序(递增小在前大在后,递减则反之。)
    ②减小增量 (因为是第一趟所以这步可以不用管)
  3. 输出数据
#include
int main(){ int n, data[1000], gap, temp, i; scanf("%d",&n);//cin >> n; for(i=0;i
> data[i]; gap=n/2;//第一趟排序,不用while循环 for(i=gap;i

以上方法仅供参考,欢迎互联网的广大朋友们提出指正。

你可能感兴趣的文章
mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
查看>>
MySQL 快速创建千万级测试数据
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
MySql 手动执行主从备份
查看>>
Mysql 批量修改四种方式效率对比(一)
查看>>
mysql 批量插入
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>