第九天、希尔排序

    用希尔排序法对一组数据由小到大进行排序,数据分别为69、56、12、136、3、55、46、99、88、25。 希尔排序的全过程如下:

代码实现:

/*第九天、希尔排序*/
#include <stdio.h>
#include <stdlib.h>
/****************************************************************************************
*希尔排序(Shell Sort)是插入排序的一种。也称缩小增量排序,是直接插入排序算法的一种更高效 *
*的改进版本。希尔排序是非稳定排序算法。该方法因DL.Shell于1959年提出而得名。            *
*希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少 *
*每组包含的关键词越来越多,当增量减至1时,整个文件恰被分成一组,算法便终止。            *
*****************************************************************************************/

/******************************************* 
*函数名称:Shsort 
*参数说明:pDataArray 无序数组指针
*          iDataNum   无序数据个数 
*说明:    希尔排序 
********************************************/  
void Shsort(int* pDataArray,int iDateNumn)
{
    int i,j,d;
    d = iDateNumn / 2;                                   /*确定固定增量值,设为数组长度的一半*/
    while(d >= 1)                                        /*增量等于1退出循环*/
    {
        for(i = d;i < iDateNumn;i++)                     /*数组下标从d开始进行直接插入排序*/
        {                                                /*也就是数组的第d+1个元素*/
            int temp = pDataArray[i];                    /*设置监视哨,元素最右边的位置*/
            j = i - d;                                   /*确定要进行比较的元素的最左边位置*/
            while((j >= 0) && (temp < pDataArray[j]))    /*从后向前,找到比其小的数的位置*/
            {
                pDataArray[j + d] = pDataArray[j];       /*数据右移*/
                j -= d;                                  /*向左移动d个位置*/
            }
            if (j != i - d)                              /*存在比其小的数*/
                pDataArray[j + d] = temp;                /*在确定的位置插入pDataArray[i]*/
        }
        d = d / 2;
    }

}

/******************************************* 
*函数名称:main
*参数说明:无
*说明:    主函数 
********************************************/  
void main(void)
{
    int pDataArray[10],i;                        
    printf("请输入10个数据:\n");
    for(i = 0;i < 10;i++)
        scanf("%d",&pDataArray[i]);
    Shsort(pDataArray,10);
    printf("排序后的顺序是:\n");
    for(i = 0;i < 10;i++)
        printf("%5d",pDataArray[i]);
    printf("\n");
    system("pause");
}

结果显示:

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏有趣的Python

慕课网-C++远征之封装篇(下)-学习笔记

C++远征之封装篇(下) c++封装概述 类 & 对象 对象+数据成员 = 对象成员 对象 + 数组 = 对象数组 深拷贝 & 浅拷贝 对象指针 & 对象指针成...

45110
来自专栏微信公众号:Java团长

JavaSE入门篇:变量

图片上的各种餐具,就是变量,因为同一个盘子可以在不同的时间装不同的菜,在这一桌可以装土豆肉丝,在下一桌可以装清炒黄瓜(当然,这个盘子还是要洗洗干净滴)。

942
来自专栏学习力

《Java从入门到放弃》JavaSE入门篇:变量

1355
来自专栏King_3的技术专栏

leetcode-657-Judge Route Circle

1734
来自专栏应兆康的专栏

遇见 Kotlin 先导篇:Kotlin 相比 Java 好在哪里?

Kotlin 是一种为现代多平台应用而诞生的静态编程语言相比于Java而言,它有很多优点,待会笔者会就几个写一下,并给出实际例子。

3884
来自专栏有趣的Python

py编程技巧-1.4-如何根据字典中值的大小对于字典中的项排序

实际案例: 某班英语成绩以字典形式存储为{'mtianyan',100,'tudou':'100','shabi':59} 根据成绩高低计算学生排名 解决...

3386
来自专栏mathor

LeetCode300. 最长上升子序列

 经典dp问题,用dp[i]表示前i+1个个数的最长上升子序列,也就是以ai为末尾的最长上升子序列长度,要注意的是dp初始化应该是1而不是0,因为对于每个...

1462
来自专栏移动端开发

内存管理说明白点

1312
来自专栏有趣的Python

7-C++远征之封装篇[下]-学习笔记

如何实例化一个对象?实例化对象对于程序是很重要的,只有实例化了对象才能访问成员函数和数据成员。

1373
来自专栏大闲人柴毛毛

Java8新特性——StreamAPI(二)

1. 收集器简介 收集器用来将经过筛选、映射的流进行最后的整理,可以使得最后的结果以不同的形式展现。 collect方法即为收集器,它接收Collector接...

2855

扫码关注云+社区