青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

elva

shellsort之二

轉(zhuǎn)自:
http://blog.sina.com.cn/s/blog_61e439e50100mfe8.html

希爾排序(shellsort)又叫增量遞減(diminishing increment)排序,是由D.L. Shell發(fā)明的,這個算法是通過一個逐漸減小的增量使一個數(shù)組逐漸趨近于有序從而達(dá)到排序的目的,該算法由1959年公布。

最差時間復(fù)雜度:根據(jù)步長序列的不同而不同。已知最好的: O(nlog2n)

最優(yōu)時間復(fù)雜度:O(n)

平均時間復(fù)雜度:根據(jù)步長序列的不同而不同。

原始的算法實現(xiàn)在最壞的情況下需要進(jìn)行O(n2)的比較和交換。V. Pratt的書[1] 對算法進(jìn)行了少量修改,可以使得性能提升至O(n log2 n)。這比最好的比較算法的O(n log n)要差一些。

希爾排序通過將比較的全部元素分為幾個區(qū)域來提升插入排序的性能。這樣可以讓一個元素可以一次性地朝最終位置前進(jìn)一大步。然后算法再取越來越大的步長進(jìn)行排序,算法的最后一步就是普通的插入排序,但是到了這步,需排序的數(shù)據(jù)幾乎是已排好的了(此時插入排序較快)。

假設(shè)有一個很小的數(shù)據(jù)在一個已按升序排好序的數(shù)組的末端。如果用復(fù)雜度為O(n2)的排序(冒泡排序或插入排序),可能會進(jìn)行n次的比較和交換才能將該數(shù)據(jù)移至正確位置。而希爾排序會用較大的步長移動數(shù)據(jù),所以小數(shù)據(jù)只需進(jìn)行少數(shù)比較和交換即可到正確位置。

一個更好理解的希爾排序?qū)崿F(xiàn):將數(shù)組列在一個表中并對列排序(用插入排序)。重復(fù)這過程,不過每次用更長的列來進(jìn)行。最后整個表就只有一列了。將數(shù)組轉(zhuǎn)換至表是為了更好地理解這算法,算法本身僅僅對原數(shù)組進(jìn)行排序(通過增加索引的步長,例如是用i += step_size而不是i++)。

例如,假設(shè)有這樣一組數(shù)[ 13 14 94 33 82 25 59 94 65 23 45 27 73 25 39 10 ],如果我們以步長為5開始進(jìn)行排序,我們可以通過將這列表放在有5行的表中來更好地描述算法,這樣他們就應(yīng)該看起來是這樣:

13 14 94 33 82

25 59 94 65 23

45 27 73 25 39

10

然后我們對每行進(jìn)行排序:

10 14 73 25 23

13 27 94 33 39

25 59 94 65 82

45

當(dāng)我們以單行來讀取數(shù)據(jù)時我們得到:[ 10 14 73 25 23 13 27 94 33 39 25 59 94 65 82 45 ].這時10已經(jīng)移至正確位置了,然后再以3為步長進(jìn)行排序:

10 14 73

25 23 13

27 94 33

39 25 59

94 65 82

45

排序之后變?yōu)椋?/font>

10 14 13

25 23 33

27 25 59

39 65 73

45 94 82

94

最后以1步長進(jìn)行排序(此時就是簡單的插入排序了)。

步長的選擇是希爾排序的重要部分。只要最終步長為1任何步長序列都可以工作。算法最開始以一定的步長進(jìn)行排序。然后會繼續(xù)以一定步長進(jìn)行排序,最終算法以步長為1進(jìn)行排序。當(dāng)步長為1時,算法變?yōu)椴迦肱判颍@就保證了數(shù)據(jù)一定會被排序。

算法如下

#include <stdio.h>

 

void output_array(int data[], int n)

{

    int i;

    for(i = 0; i < n; i++)

        printf("%d ", data[i]);

    printf("\n");

}

void swap(int *a, int *b)

{

    int x;

    x = *a;

    *a = *b;

    *b = x;

}

void insertion_sort(int data[], int n, int increment)

{

    int i, j;

    for(i = increment; i < n; i += increment)

        for(j = i; j >= increment && data[j] > data[j - increment]; j -= increment)

            swap(&data[j], &data[j - increment]);

}

void shellsort(int data[], int n)

{

    int i, j;

    for(i = n / 2; i > 2; i /= 2)

        for(j = 0; j < i; j++)

            insertion_sort(data + j, n - j, i);

    insertion_sort(data, n, 1);

}

int main()

{

    int data[] = {5, 3, 1, 665, 77, 66, 44, 11, 10, 9, 8, 6};

    output_array(data, 12);

    shellsort(data, 12);

    output_array(data, 12);

    return 0;

}

posted on 2010-11-01 18:08 葉子 閱讀(408) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
      <noscript id="pjuwb"></noscript>
            <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
              <dd id="pjuwb"></dd>
              <abbr id="pjuwb"></abbr>
              国产精品欧美经典| 欧美一区二区三区在线观看| 欧美激情四色| 久久最新视频| 欧美成人午夜77777| 欧美韩日一区二区| 欧美日本精品| 国产精品国产三级国产专播精品人| 欧美日韩亚洲综合| 国产精品高清一区二区三区| 国产精品日韩专区| 国产一区二区三区丝袜| 18成人免费观看视频| 亚洲韩国青草视频| 日韩一区二区电影网| 亚洲欧美日韩精品综合在线观看| 欧美在线综合| 毛片基地黄久久久久久天堂| 欧美大片免费观看| 一本一本久久a久久精品综合妖精| 亚洲欧美成人| 女生裸体视频一区二区三区| 欧美三级第一页| 国产视频欧美视频| 亚洲精品一区二区三区樱花| 欧美在线精品免播放器视频| 亚洲大胆人体视频| 欧美激情自拍| 亚洲欧美中文字幕| 欧美电影资源| 韩日精品视频| 亚洲一区在线播放| 亚洲第一黄色网| 欧美一区二区国产| 欧美视频在线观看免费网址| 国内外成人免费激情在线视频| 一本色道婷婷久久欧美| 另类酷文…触手系列精品集v1小说| 一本色道久久加勒比精品| 久久影音先锋| 国产模特精品视频久久久久| 日韩一级片网址| 欧美风情在线观看| 久久av一区二区三区亚洲| 欧美午夜久久久| 99亚洲视频| 亚洲电影自拍| 麻豆av一区二区三区久久| 国产日韩精品视频一区| 在线视频你懂得一区二区三区| 国产视频亚洲| 欧美日韩一区二区免费在线观看| 尤物在线精品| 久久久噜噜噜久久狠狠50岁| 亚洲一区中文字幕在线观看| 欧美另类视频| 亚洲精品免费一二三区| 美女诱惑黄网站一区| 午夜视频在线观看一区| 国产精品欧美在线| 亚洲自拍三区| 一区二区日本视频| 国产精品第一区| 性高湖久久久久久久久| 亚洲一区欧美一区| 国产精品久久久久久亚洲调教 | 国产一区二区三区在线观看网站| 亚洲一区国产| 中国成人亚色综合网站| 欧美午夜在线| 午夜精品免费| 欧美一区二区啪啪| 韩国精品一区二区三区| 久久成人18免费观看| 新67194成人永久网站| 好吊色欧美一区二区三区四区| 久久精品亚洲一区| 久久精品欧美日韩| 在线日韩电影| 最新中文字幕亚洲| 欧美午夜精品久久久| 欧美一区激情| 久久伊伊香蕉| 艳女tv在线观看国产一区| 正在播放欧美视频| 国产综合欧美在线看| 欧美激情视频免费观看| 欧美性事在线| 久久婷婷国产综合国色天香| 欧美aaaaaaaa牛牛影院| 亚洲一区免费| 久久久久久国产精品一区| 亚洲精品美女久久7777777| 亚洲视频在线二区| 怡红院精品视频| 亚洲精选一区二区| 国产区精品视频| 亚洲国产高清一区| 国产精品视区| 欧美成年人网站| 国产精品扒开腿做爽爽爽软件 | 亚洲靠逼com| 亚洲视频福利| 亚洲黄色成人| 亚洲欧美日韩国产中文在线| 亚洲电影毛片| 亚洲精品女人| 欧美在线一二三四区| 免费观看欧美在线视频的网站| 亚洲伊人观看| 玖玖综合伊人| 久久成人免费视频| 欧美紧缚bdsm在线视频| 久久久久久久久久久久久久一区 | 亚洲免费伊人电影在线观看av| 一区二区亚洲精品国产| 亚洲午夜精品福利| 亚洲精品日韩激情在线电影| 久久黄色小说| 欧美在线观看视频| 欧美性猛交xxxx免费看久久久| 欧美高清在线观看| 国产区在线观看成人精品| 亚洲性av在线| 亚洲一区在线视频| 欧美久久久久中文字幕| 亚洲高清视频一区二区| 一区在线播放| 久久蜜桃资源一区二区老牛| 久久精品国产亚洲a| 国产精品一二一区| 亚洲视频电影在线| 亚洲欧美国产高清va在线播| 欧美日韩午夜激情| 日韩视频三区| 亚洲视频一区二区| 欧美日韩国产系列| 亚洲精品小视频| aa级大片欧美| 欧美日韩精品一区视频| 99国产精品久久久久老师| 一本色道久久综合亚洲精品不卡| 欧美精品成人| 99国产精品久久久久久久成人热| 亚洲美女区一区| 欧美理论片在线观看| 亚洲乱亚洲高清| 亚洲综合精品| 国产乱码精品| 久久国产视频网站| 美脚丝袜一区二区三区在线观看 | 国产一区二区精品在线观看| 欧美制服丝袜| 欧美大片一区二区三区| 亚洲精品视频在线看| 欧美精品一区二区蜜臀亚洲| 亚洲乱码国产乱码精品精天堂| 亚洲欧美日韩电影| 国产最新精品精品你懂的| 久久久免费观看视频| 亚洲激情成人| 亚洲香蕉网站| 国际精品欧美精品| 欧美久久久久中文字幕| 亚洲已满18点击进入久久| 久久九九免费| 亚洲三级性片| 国产精品三上| 美女黄毛**国产精品啪啪| 亚洲美女一区| 久久亚洲国产成人| 99国产精品视频免费观看一公开 | 99视频超级精品| 亚洲欧美日韩久久精品| 韩日精品视频| 欧美性大战久久久久久久| 久久精品99无色码中文字幕| 亚洲电影观看| 欧美一区二区在线播放| 亚洲精品免费一二三区| 国产日韩专区在线| 欧美精品九九99久久| 午夜在线成人av| 亚洲国产精品一区制服丝袜 | 亚洲国产va精品久久久不卡综合| 一区二区三区欧美激情| 国语自产在线不卡| 欧美日本成人| 裸体女人亚洲精品一区| 午夜日韩视频| 亚洲美女黄色| 欧美69wwwcom| 久久福利视频导航| 国产精品99久久久久久久久久久久| 韩国精品久久久999| 国产精品国产三级国产普通话三级 | 国产精品日韩电影| 男女av一区三区二区色多| 午夜在线不卡| 亚洲欧美视频一区|