A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© strongfish 中级黑马   /  2015-7-15 10:26  /  561 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

将数组用希尔排序从小到大排序并输出.希尔排序是在直接插入排序的基础上做的改进,也就是将要排序的序列按固定增量分成若干组,等距离者在同一组中,然后再在组内进行直接插入排序.这里的固定增量从Size/2开始,以后每次缩小到原来的一半!
  1. # include <stdio.h>
  2. # define Size 10               //数组长度

  3. int main()
  4. {
  5.         int number[Size] = { 2, 4, 6, 7, 9, 5, 4, -4, 0, 10 };
  6.         int gap = Size / 2;     //增量值
  7.         int temp;

  8.         while (gap > 0)  //增量必须大于0
  9.         {
  10.                 for (int i = gap; i < Size; i++) //数组行下标gap进行直接插入排序
  11.                 {
  12.                         temp = number[i];
  13.                         int l = i - gap;         //确定右边的需要进行比较的元素
  14.                         while (l >= 0 && temp < number[l])
  15.                         {
  16.                                 number[l + gap] = number[l];   //数据右移
  17.                                 l -= gap;
  18.                         }
  19.                         number[l + gap] = temp;   //在确定的位置插入
  20.                 }
  21.                 gap /= 2;
  22.         }

  23.         for (int i = 0; i < Size; i++)
  24.         {
  25.                 printf("%d ", number[i]);
  26.         }

  27.         return 0;
  28. }
复制代码

注: 希尔排序是插入排序的一种, 分组插入排序。

2 个回复

倒序浏览
恩哦 啊,奥额呵哈。
回复 使用道具 举报
学习了~
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马