【数据结构】【C#】015-插入类排序:🥉希尔排序(不稳定)

插入排序:希尔排序(不稳定)

【算法改进要点 】 直接插入排序法,在待排序的关键字序列基本有序且关键字个数 n 较少
时,其算法的性能最佳。 希尔排序又称缩小增量排序法,是一种基于插入思想的排序方法,
它利用了直接插入排序的最佳性质,①将待排序的关键字序列分成若干个较小的子序列,对
子序列进行直接插入排序,使整个待排序序列排好序。在时间耗费上,较直接插入排序法的
性能有较大的改进。②在进行直接插入排序时,若待排序记录序列已经有序时,直接插入排
序的时间复杂度可以提高到 O(n)。若待排序记录序列基本有序时,即序列中具有下列特性的
记录较少时: r[i].key<Max{ r[j].key},(1≤j<i),直接插入排序的效率会大大提高。希尔排序
正是基于以上两点对直接插入排序进行了改进。

【 算法思想 】 先将待排序记录序列分割成若干个“较稀疏的”子序列,分别进行直接插入排序。经过上述粗略调整,整个序列中的记录已经基本有序,最后再对全部记录进行一次直接插入排序。
①首先选定记录间的距离为 d i (i=1),在整个待排序记录序列中将所有间隔为 d 1 的记录分成一组,进行组内直接插入排序;

②然后取 i=i+1, 记录间的距离为 d i (d i <d i-1 ),在整个待排序记录序列中,将所有间隔为di 的记录分成一组,进行组内直接插入排序;

重复步骤②多次,直至记录间的距离 d i =1,此时整个只有一个子序列,对该序列进行直接插入排序,完成整个排序过程。


C#实现:


/// <summary>
/// 自定义工具类
/// </summary>
public static class Utilit
{
    /// <summary>
    /// 辅助输出排序结果:
    /// </summary>
    /// <param name="a"></param>
    /// <param name="t"></param>
    public static void Print(int[] a, int t)
    {
        string str = null;
        for (int i = 0; i < a.Length; i++)
        {
            str += a[i].ToString() + " ";
        }
        Debug.Log("第" + t + "趟排序结果:" + str);
    }

    /// <summary>
    /// 辅助生成排序结果
    /// </summary>
    /// <param name="max"></param>
    /// <param name="length"></param>
    /// <returns></returns>
    public static int[] RandArray(int max, int length)
    {
        string str = null;
        int[] a = new int[length];
        for (int i = 0; i < a.Length; ++i)
        {
            a[i] = Random.Range(0, max);
            str += a[i].ToString() + " ";
        }
        Debug.Log("随机生成的数组:" + str);
        return a;
    }
}

上方为产生随机数组与打印排序数组的工具类

希尔排序:

/// <summary>
/// 插入排序类
/// </summary>
public class InsertSort
{

    /// <summary>
    /// 3、希尔排序
    /// </summary>
    /// <param name="a"></param>    
    public  static void ShellSort(int[] a)
    {
        int len = a.Length;
        while (len != 0)
        {
            len = len / 2;
            for (int i = 0; i < len; i++)//分组
            {
                for (int j = i + len; j < a.Length; j += len)
                {
                    int k = j - len;//k为有序序列最后一个的位置
                    int temp = a[j];
                    while (k >= 0 && temp < a[k])
                    {
                        a[k + len] = a[k];
                        k -= len;
                    }
                    a[k + len] = temp;
                }

                Utilit.Print(a, i); //打印
            }
        }

    }

}

测试用例:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class _012_InsertSort : MonoBehaviour
{


    void Start()
    {
        int[] a = Utilit.RandArray(20, 10);

        //Debug.Log("------------直接插入排序----------------");
        //InsertSort.StraightInsetSort(a); //直接插入排序

        Debug.Log("------------折半插入排序----------------");
        InsertSort.BInsertSort(a); //折半插入排序

        //Debug.Log("------------希尔排序----------------");
        //InsertSort.ShellSort(a);//希尔排序


    }

}

输出结果:

i插入排序:希尔排序

注:

时间复杂度

当 d i =1 时,尽管这一趟希尔排序相当于直接插入排序,但因为此时序列的逆转数很小,所以移动次数相对于简单的直接插入排序而言也会减少。由此可见,希尔排序是一个较好的插入排序方法。希尔排序能迅速减少逆转数,尽管当间隔为 1 时,它相当于直接插入排序,但此时的关键字序列的逆转数已经很小,序列已经基本有序,使用的恰好是直接插入的最佳性质,它的时间复杂度为 O(n 1.5 ),比直接插入要好。
希尔排序对于中等规模(n<=1000)的序列具有较高的效率,且希尔排序算法简单,容易执行。因此很多排序应用程序都选用了希尔排序算法

算法稳定性

希尔排序的分析是一个复杂的问题,因为它的时间耗费是所取的“增量”序列的函数。
到目前为止,尚未有人求得一种最好的增量序列。但大量研究也得出了一些局部的结论。
在排序过程中,相同关键字记录的领先关系发生变化,则说明该 排序方法是不稳定的。
例如,待排序序列{2^,4,1,2}, 采用希尔排序,设 d 1 =2, {2,4,1,2},得到一趟排序结果为{1,2,2^,4},说明希尔排序法是不稳定的排序方法,两个2的顺序发生了变化。


插入排序类总结:

img.jpg
img.jpg
image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 一、 单项选择题(共71题) 对n个元素的序列进行冒泡排序时,最少的比较次数是( )。A. n ...
    貝影阅读 9,057评论 0 10
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,250评论 0 2
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,178评论 0 52
  • 随着课程训练的逐步拉开,孩子们的参与度越来越高,七连七班的孩子们今天又发生了哪些故事呢?让我们来看一下。 内务卫生...
    夜空的星落向晨曦的海阅读 470评论 1 0
  • 最近楼市话题充斥着各种媒体,更成为各类人群饭桌上最常聊的话题,清华北大硕士买不起房的故事也着实给一些“屌丝”带来一...
    蛙哥理财手记阅读 409评论 0 0