C#排序算法之希尔排序

希尔排序.gif
  1. 希尔排序,也叫缩小增量排序,是直接插入排序算法的一种更高效的版本,适合中级数量级的排序,属于非稳定排序算法。

  2. 原理:以升序为例,该方法实质上是分组插入排序,比较相隔较远距离(称为[增量]的数,使得数移动时能跨过多个元素,则进行一次比较就可能消除多个元素交换。思考一下,直接插入排序是什么时候最高效呢,1.数据量少。2.数据数组有序。而希尔排序可以提前将局部数组变得有序,减少了数据移动的步骤。

  3. 思路:在数组中[8,9,1,7,2,3,5,4,6,0],选取增量为5的数据进行比较,第二次增量为2,第三次增量为1,以此类推。
    以数组[8,9,1,7,2,3,5,4,6,0]为例:
    第1次排序:[3,5,1,6,0,8,9,4,7,2]
    第2次排序:[0,2,1,4,3,5,7,6,9,8]
    第3次排序:[0,1,2,3,4,5,6,7,8,9]

4.举例:
(1)要排序的数组是:[15, 22, 35, 9, 16, 33, 15, 23, 68, 1, 33, 25, 14]。

  //希尔排序是直接排序算法的一种变形,比直接排序算法灵活。
    static void Main(string[] args)
    {
        int[] array = { 15, 22, 35, 9, 16, 33, 15, 23, 68, 1, 33, 25, 14 };     //待排序数组
        //int[] array = { 9, 1, 2, 5, 7, 4, 8, 6, 3, 5};                          //待排序数组
        //int[] array = { 592, 401, 874, 141, 348, 72, 911, 887, 820, 283 };      //待排序数组
        //int[] array = { 61, 109, 149, 111, 34, 2, 24, 119, 122, 125, 27, 145};  //待排序数组 
        int gap = array.Length / 2;

        while (gap > 0)
        {
            Console.WriteLine(gap);
            //ShellSort_1(array, gap, array.Length);
            ShellSort(array, gap);
            gap = gap / 2;
            Console.WriteLine("希尔排序后的数列:");
            foreach (int item in array)
                Console.Write(item + " ");
            Console.WriteLine();
        }

        //控制台遍历输出
        Console.ReadLine();
    }
    /// <summary>
    /// 希尔排序
    /// </summary>
    /// <param name="array">要排序的数列</param>
    /// <param name="gap">  要进行比较的数列间隔</param>
    static void ShellSort(int[]array,int gap)
    {
        for(int i = 0;i < array.Length-gap; i++)
        {
            if(array[i]>array[i + gap])
            {
                int temp = array[i];
                array[i] = array[i + gap];
                array[i + gap] = temp;

                int j;
                j = i;
                do
                {
                    if (j - gap < 0) break;
                    if (array[j] >= array[j - gap])
                    {
                        break;
                    }
                    else
                    {
                        int temp1 = array[j];
                        array[j] = array[j - gap];
                        array[j - gap] = temp1;
                    }
                    j = j - gap;
                }
                while (j > 0);
            }
        }
    }

5.输出结果
增量:6
希尔排序后的数列:
14 22 35 1 16 25 15 23 68 9 33 33 15
增量:3
希尔排序后的数列:
1 16 25 9 22 33 14 23 35 15 33 68 15
增量:1
希尔排序后的数列:
1 9 14 15 15 16 22 23 25 33 33 35 68

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

推荐阅读更多精彩内容