`
chenzehe
  • 浏览: 539575 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

希尔排序算法分析及程序示例

阅读更多
实例说明

  用希尔排序方法对数组进行排序。


实例解析

  希尔排序 (Shell Sort) 是插入排序的一种。希尔排序基本思想是先取一个小于 n 的整数 d1 作为第一个增量,把文件的全部记录分成 d1 个组。所有距离为 d1 的倍数的记录放在同一个组中。先在各组内进行直接插入排序;然后,取第二个增量 d2<d1 重复上述的分组和排序,直至所取的增量 dt=1(dt<dt-1<…<d2<d1), 即所有记录放在同一组中进行直接插入排序为止。该方法实质上是一种分组插入方法。


Shell 排序的算法描述如下 :

void ShellPass(SeqList R,int d){ // 希尔排序中的一趟排序, d 为当前增量
  for(i=d+1;i<=n;i++)      // 将 R[d+1..n] 分别插入各组当前的有序区
    if(R[i].key<R[i-d].key){
      R[0]=R[i]; j=i-d;   //R[0] 只是暂存单元,不是哨兵
      do{          // 查找 R[i] 的插入位置
        R[j+d]=R[j];   // 后移记录
        j=j-d;      // 查找前一记录
      }while(j>0 && R[0].key < R[j].key);
      R[j+d]=R[0];     // 插入 R[i] 到正确的位置上
    } //endif
}//ShellPass

void ShellSort(SeqList R){
  int increment=n;        // 增量初值,设 n>0
  do{
    increment=increment/3+1; // 求下一增量
    ShellPass(R,increment);  // 一趟增量为 increment 的 Shell 插入排序
  }while(increment>1);
}//ShellSort

  注意:当增量 d=1 时,希尔排序和插入排序基本一致,只是由于没有哨兵而在内循环中增加了一个循环判定条件“ j> 0 ”,以防下标越界。


程序代码—希尔排序

#include <stdio.h>
#define MAX 255
int R[MAX];

void ShellPass(int d,int n){ /* 希尔排序中的一趟排序, d 为当前增量 */
   int i,j;
   for(i=d+1;i<=n;i++) /* 将 R[d+1..n] 分别插入各组当前的有序区 */
      if(R[i]<R[i-d]){
         R[0]=R[i]; j=i-d; /*R[0] 只是暂存单元,不是哨兵 */
         do{ /* 查找 R[i] 的插入位置 */
            R[j+d]=R[j]; /* 后移记录 */
            j=j-d; /* 查找前一记录 */
         }while(j>0 && R[0]<R[j]);
         R[j+d]=R[0]; /* 插入 R[i] 到正确的位置上 */
      }/*endif*/
}/*end of ShellPass*/

void Shell_Sort(int n){
   int increment=n; /* 增量初值,设 n>0*/
   do{
      increment=increment/3+1; /* 求下一增量 */
      ShellPass(increment,n); /* 一趟增量为 increment 的 Shell 插入排序 */
   }while(increment>1);
}/*ShellSort*/

void main(){
   int i,n;
   clrscr();
   puts("Please input total element number of the sequence:");
   scanf("%d",&n);
   if(n<=0 || n>MAX){
      printf("n must more than 0 and less than %d.\n",MAX);
      exit(0);
   }
   puts("Please input the elements one by one:");
   for(i=1;i<=n;i++)
      scanf("%d",&R[i]);
   puts("The sequence you input is:");
   for(i=1;i<=n;i++)
      printf("%4d",R[i]);
   Shell_Sort(n);
   puts("\n The sequence after shell_sort is:");
   for(i=1;i<=n;i++)
      printf("%4d",R[i]);
   puts("\n Press any key to quit…");
   getch();
}


归纳注释

  增量序列的选择:希尔排序的执行时间依赖于增量序列。好的增量序列的共同特征: ① 最后一个增量必须为 1; ② 尽量避免序列中的值 ( 尤其是相邻的值 ) 互为倍数的情况。有人通过大量的实验,给出了目前较好的结果:当 n 较大时,比较和移动的次数约在 n^( 1.25)~1.6n^( 1.25) 之间。

  希尔排序的时间性能优于直接插入排序,因为: ① 当文件初态基本有序时直接插入排序所需的比较和移动次数均较少。 ② 当 n 值较小时, n 和 n^2 的差别也较小,即直接插入排序的最好时间复杂度 O(n) 和最坏时间复杂度 O(n^2) 差别不大。 ③ 在希尔排序开始时增量较大,分组较多,每组的记录数目少,故各组内直接插入较快,后来增量 di 逐渐缩小,分组数逐渐减少,而各组的记录数目逐渐增多,但由于已经按 di-1 作为距离排过序,使文件较接近于有序状态,所以新的一趟排序过程也较快。因此,希尔排序在效率上较直接插入排序有较大的改进。

  稳定性:希尔排序是不稳定的。因为两个相同关键字在排序前后的相对次序发生了变化。
分享到:
评论

相关推荐

    希尔排序(程序).txt

    根据提供的代码片段,我们可以看到一个具体的希尔排序实现示例。下面将对该代码进行详细解析: ```c #include #define MAX 255 int R[MAX]; void ShellPass(int d, int n) { /* 对数组进行增量为d的希尔排序 */ ...

    七种常见的VB排序算法示例程序

    本篇将深入探讨七种常见的VB排序算法示例程序,它们包括:冒泡排序、选择排序、插入排序、快速排序、归并排序、堆排序和希尔排序。 1. 冒泡排序(Bubble Sort) 冒泡排序是最基础的排序算法之一,通过不断交换相邻...

    C语言实现希尔排序

    希尔排序(Shell Sort)是由Donald Shell于1959年提出的一种排序算法,它是对直接插入排序的一种改进。其基本思想是先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,具体做法是:首先选择一个增量...

    希尔排序法(希尔插入排序,希尔交换排序)

    根据题目中的描述和部分代码示例,我们可以进一步了解希尔排序的具体实现细节。 ##### 1. 希尔插入排序 希尔插入排序是希尔排序中最常见的实现方式之一,其基本步骤如下: - **初始化增量**:选择一个初始增量值...

    Java实现希尔排序算法(源代码)

    ### Java实现希尔排序算法 #### 实现原理 希尔排序(Shell Sort)是插入排序的一种高效改进版本,也称为缩小增量排序。它的基本思想是:先将整个待排序的记录序列分割成为若干子序列(由相隔某个“增量”的记录...

    C++ 实现的简单的希尔排序的算法

    通过上述分析可以看出,该示例代码实现了一种基于C++语言的希尔排序算法。通过对不同间隔值的处理,该算法能够有效地提高排序效率,尤其是在大数据量的情况下表现更为突出。此外,希尔排序的简单性和高效性使其成为...

    内部排序 希尔排序和直接插入排序的比较

    本篇文章将通过一组具体的数据集(8个整数)对直接插入排序(Direct Insertion Sort)和希尔排序(Shell Sort)这两种排序方法进行深入分析和比较。这两种排序算法在实际应用中都非常常见,各有优劣。 #### 二、...

    基于JavaScript实现的希尔排序算法分析

    JavaScript实现的希尔排序算法示例代码中,首先定义了一个间隔序列数组`gaps`。在实际的排序过程中,按照间隔序列中的值作为步长,逐个对数组元素进行分组排序。初始时,步长较大,元素之间比较的间隔远,减少每一轮...

    希尔排序(java)

    希尔排序(Shell Sort)是一种基于插入排序的快速排序算法,由Donald Shell于1959年提出。它的主要思想是将待排序的数据按照一个增量序列分成若干个子序列,然后分别对子序列进行插入排序,最后再进行一次整体的插入...

    插入类排序算法

    - `shell_inst` 文件可能包含希尔排序的实现代码或示例,帮助读者理解希尔排序的步骤和增量序列的选择方法。 - `straight_inst` 文件可能包含了直接插入排序的实现,展示了如何遍历序列并逐个插入元素的过程。 - `...

    Python排序搜索基本算法之希尔排序实例分析

    该程序将按照希尔排序算法对给定的数组进行排序。运行结果会输出排序后的数组。 #### 性能分析 - **时间复杂度**:希尔排序的时间复杂度依赖于步长序列的选择。对于Knuth的步长序列,平均情况下的时间复杂度接近O...

    希尔排序的一个程序,文本的哦,可以参考,欢迎下载

    **希尔排序算法实现** 在给定的代码片段中,并没有直接体现希尔排序的核心思想。实际上,希尔排序的关键在于增量的选择和更新方式。常见的增量序列有Hibbard增量、Sedgewick增量等。但是,为了更好地理解希尔排序...

    C语言经典排序算法及举例(非常实用)

    以下是对标题"《C语言经典排序算法及举例》"中涉及的排序算法进行的详细解释: 1. **冒泡排序**: 冒泡排序是最基础的排序算法之一,它通过重复遍历待排序的数组,依次比较相邻元素并交换顺序,使较大的元素逐渐...

    C#四种排序算法 冒泡排序、选择排序、插入排序和希尔排序

    ### C#中的四种排序算法详解 #### 一、冒泡排序 冒泡排序是一种简单的排序算法,它重复地遍历待排序的数列,依次比较相邻的两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复进行的,直到没有...

    各种排序算法比较

    文档中提供了几种排序算法的具体实现思路,这里选取两种算法进行详细分析: #### 1、选择排序 - **功能**:对数组进行升序排列。 - **输入**:数组名称及其元素数量。 - **算法思想**:通过每次从剩余未排序的部分...

    6中简单的排序算法分析

    根据提供的文件信息,本文将对六种常见的排序算法进行详细解析与分析,这些算法包括:快速排序、冒泡排序、希尔排序(稀尔排序)、堆排序、选择排序等。每种算法都有其特点和适用场景,理解它们的工作原理有助于更好...

    数据结构内部排序算法比较.doc

    本次实验的主要目的是通过实际操作来比较六种常用的内部排序算法(起泡排序、直接插入排序、简单选择排序、快速排序、希尔排序、堆排序)在处理随机数据时的关键字比较次数和关键字移动次数,以便直观地了解每种算法...

    排序算法的相关说明和示例

    本文将详细介绍六种常见的排序算法:选择排序、直接插入排序、冒泡排序、希尔排序、快速排序,并给出相应的示例。 #### 1. 选择排序(Selection Sort) **基本思想:** 选择排序是一种简单直观的比较排序算法。它...

    插入排序算法C语言程序.zip

    - 了解插入排序有助于理解其他更复杂的排序算法,如希尔排序(一种改进的插入排序)。 总的来说,这个"插入排序算法C语言程序"项目提供了一个实践插入排序算法的机会,可以帮助开发者加深对排序算法的理解,尤其是...

    排序算法大集合,包括各种算法

    在计算机科学领域,排序算法是数据结构与算法分析的重要组成部分,它主要负责将一组数据按照特定的顺序进行排列。这个压缩包文件“排序算法大集合”显然包含了多种排序算法的详细说明和实例,旨在帮助我们理解和掌握...

Global site tag (gtag.js) - Google Analytics