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

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>
              亚洲国产精品毛片| 亚洲自拍啪啪| 99精品免费网| 欧美一区二区三区在线| 久久综合中文色婷婷| 亚洲一区二区高清| 精品福利av| 免费不卡中文字幕视频| 久久久久久久久久久久久9999 | 国产精品大片wwwwww| 亚洲精品日韩激情在线电影 | 亚洲高清免费| 欧美色一级片| 亚洲国产一区二区视频| 国产在线欧美| 一本色道久久99精品综合| 欲香欲色天天天综合和网| 亚洲视频免费在线观看| 一区二区三区视频在线看| 蜜臀av一级做a爰片久久| 久久亚洲精品网站| 国产欧美精品| 欧美伊人精品成人久久综合97| 亚洲特级毛片| 欧美亚洲成人精品| 久久久免费av| 亚洲精品美女在线| av成人免费在线观看| 麻豆av一区二区三区| 伊人精品在线| 久久久高清一区二区三区| 亚洲欧美另类中文字幕| 亚洲自拍都市欧美小说| 久久久久久久激情视频| 欧美日韩专区| 亚洲综合精品一区二区| 黄色精品一二区| 在线午夜精品自拍| 亚洲精选在线观看| 一区二区三区久久久| 亚洲激情影院| 亚洲女与黑人做爰| 亚洲欧美日韩精品久久| 国产精品久99| 久久综合99re88久久爱| 欧美国产在线视频| 一区二区欧美在线| 国产精品欧美一区二区三区奶水| 午夜精品免费视频| 欧美+日本+国产+在线a∨观看| 亚洲精品一区二区三区四区高清| 欧美精品久久一区| 亚洲一区二区三区中文字幕| 久久久精品日韩| 一区二区三区免费看| 激情久久一区| 国产乱码精品一区二区三区忘忧草 | 欧美日韩国产免费| 校园春色综合网| 夜夜爽www精品| 亚洲黄色有码视频| 久久久99久久精品女同性| 在线亚洲自拍| 洋洋av久久久久久久一区| 国内精品久久久久伊人av| 久久免费少妇高潮久久精品99| 亚洲国产天堂网精品网站| 国产精品久久久久久影院8一贰佰| 久久天堂精品| 老司机精品导航| 欧美99久久| 欧美激情一区二区三区高清视频| 久久久噜久噜久久综合| 久久久免费av| 欧美激情中文字幕乱码免费| 欧美大片免费看| 国产精品啊啊啊| 国产九区一区在线| 国产视频综合在线| 亚洲激情视频在线| 亚洲一区精彩视频| 久久不射中文字幕| 欧美电影免费| 中日韩高清电影网| 亚洲欧美日本伦理| 久久久www成人免费精品| 久久综合九色| 国产精品一区二区女厕厕| 精品999日本| 亚洲永久免费精品| 亚洲成在线观看| 国产精品日韩欧美一区二区| 国模一区二区三区| 亚洲一区二区在线播放| 欧美α欧美αv大片| 亚洲欧美国产日韩天堂区| 久久青草福利网站| 国产精品亚洲综合久久| 夜夜狂射影院欧美极品| 欧美大片91| 久久综合九色99| 亚洲国产欧美日韩另类综合| 欧美一区二区网站| 午夜精品福利电影| 国产精品久久久久久亚洲毛片| 99在线热播精品免费| 亚洲国产黄色| 欧美精品www在线观看| 欧美一级片一区| 国产日韩欧美一区在线| 亚洲午夜性刺激影院| 亚洲精品在线电影| 欧美日韩性视频在线| 亚洲欧美国产77777| 在线亚洲免费视频| 国产精品综合视频| 久久久久久久久综合| 久久久亚洲午夜电影| 亚洲激情社区| 亚洲免费在线看| 在线日韩av片| 中文欧美字幕免费| 国产一区二区在线免费观看| 欧美1级日本1级| 欧美日韩一级视频| 久久久美女艺术照精彩视频福利播放 | 欧美日韩另类字幕中文| 午夜伦理片一区| 久久影视三级福利片| 这里只有精品视频在线| 久久精品国产91精品亚洲| 亚洲国产精品123| 亚洲欧美国产毛片在线| 日韩视频精品| 久久一区二区精品| 久久黄色小说| 国产精品v日韩精品| 亚洲国产精品一区二区www| 国产精品午夜在线| 亚洲视频视频在线| 亚洲理伦电影| 欧美精品一区视频| 亚洲第一二三四五区| 亚洲国产精品福利| 久久久伊人欧美| 美女精品一区| 亚洲电影免费观看高清| 久久久噜噜噜久久久| 久久综合电影| 亚洲青色在线| 女人天堂亚洲aⅴ在线观看| 国产欧美大片| 老色批av在线精品| 欧美国产三区| 一区电影在线观看| 欧美日韩午夜剧场| 亚洲视频在线观看视频| 午夜精品在线视频| 1769国内精品视频在线播放| 久久久一区二区三区| 欧美第一黄网免费网站| 正在播放亚洲一区| 国产三区二区一区久久| 久热精品视频在线| 一本色道久久综合亚洲精品按摩 | 国产日产欧产精品推荐色| 久久成人av少妇免费| 亚洲欧洲一区二区三区久久| 午夜精品久久久久久久久久久 | 欧美婷婷久久| 欧美在线综合| 亚洲男人第一av网站| 欧美激情久久久久久| 欧美在线首页| 西西人体一区二区| 亚洲理伦电影| 欧美日韩国产综合新一区| 久久久久九九视频| 在线视频亚洲欧美| 亚洲精品免费网站| 国产欧美日韩中文字幕在线| 欧美激情视频在线免费观看 欧美视频免费一| 国产精品99久久久久久久女警| 欧美高清在线精品一区| 免费成人在线视频网站| 欧美在线观看网址综合| 亚洲午夜精品网| 亚洲自拍另类| 性欧美大战久久久久久久久| 亚洲综合不卡| 亚洲欧美在线一区二区| 性欧美xxxx大乳国产app| 久久九九精品| 久久中文字幕一区| 欧美国产高清| 一区二区三区国产精华| 一本久道久久久| 午夜精品福利在线| 欧美国产日本韩| 99视频有精品|