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

MyMSDN

MyMSDN記錄開發(fā)新知道

希爾排序(Shell sort)排序算法

Shell排序算法是D.L.Shell于1959年發(fā)明的,其基本思想是:

下面的這段代碼是Shell算法的C語言實(shí)現(xiàn),其中shellsort為原函數(shù),而traceShellsort則為跟蹤輸出的函數(shù),這里我用了幾個(gè)標(biāo)準(zhǔn)輸出的語句,將數(shù)據(jù)交換的過程進(jìn)行一個(gè)輸出,以更好地理解排序的過程。

#include <stdio.h>
#include <stdlib.h>
#define ARRAY_LENGTH 9
void shellsort(int v[], int n);
void arrayPrintf(int v[], int n);
void traceShellsort(int v[], int n);
int traceOut(int n, int gap, int i, int j, int isnewline);
int traceCount;
int main(void) {
int arr[ARRAY_LENGTH] = { 12, 2, 20, 19, 28, 30, 12, 42, 35 };
printf("Original array:\t\t");
arrayPrintf(arr, ARRAY_LENGTH);
/*sort the array by shell arithmetic*/
//shellsort(arr, ARRAY_LENGTH);
traceShellsort(arr, ARRAY_LENGTH);
putchar('\n');
printf("MinToMax array:\t\t");
arrayPrintf(arr, ARRAY_LENGTH);
return EXIT_SUCCESS;
}
/*shellsort函數(shù):按遞增順序?qū)[0]…v[n-1]進(jìn)行排序*/
void shellsort(int v[], int n) {
int gap, i, j, temp;
for (gap = n / 2; gap > 0; gap /= 2)
for (i = gap; i < n; i++)
for (j = i - gap; j >= 0 && v[j] > v[j + gap]; j -= gap) {
temp = v[j];
v[j] = v[j + gap];
v[j + gap] = temp;
}
}
/*shell排序算法的跟蹤版,相同的算法,它將輸出帶有跟蹤過程的數(shù)據(jù)*/
void traceShellsort(int v[], int n) {
int gap, i, j, temp;
extern int traceCount;
traceCount = 1;
for (gap = n / 2; gap > 0; gap /= 2) {
for (i = gap; i < n; i++) {
for (j = i - gap; traceOut(n, gap, i, j, !(j >= 0 && v[j] > v[j
+ gap])) && j >= 0 && v[j] > v[j + gap]; j -= gap) {
temp = v[j];
v[j] = v[j + gap];
v[j + gap] = temp;
arrayPrintf(v, n);
}
}
}
}
/*用于跟蹤交換過程*/
int traceOut(int n, int gap, int i, int j, int isnewline) {
printf("%2d. n=%d gap=%d i=%d j=%2d %c", traceCount++, n, gap, i, j,
isnewline ? '\n' : ' ');
return 1;
}
/*用于輸出一組數(shù)組*/
void arrayPrintf(int v[], int n) {
int i;
for (i = 0; i < n; i++)
printf("%d ", v[i]);
putchar('\n');
}

下面的文字是運(yùn)行上面一段代碼后產(chǎn)生的結(jié)果,其中跟蹤過程中出現(xiàn)的數(shù)組輸出,表示該數(shù)組步驟中將會(huì)產(chǎn)生一次位置交換過程。

Original array:		12 2 20 19 28 30 12 42 35
1. n=9 gap=4 i=4 j=0
2. n=9 gap=4 i=5 j=1
3. n=9 gap=4 i=6 j=2  12 2 12 19 28 30 20 42 35
4. n=9 gap=4 i=6 j=-2
5. n=9 gap=4 i=7 j=3
6. n=9 gap=4 i=8 j=4
7. n=9 gap=2 i=2 j=0
8. n=9 gap=2 i=3 j=1
9. n=9 gap=2 i=4 j=2
10. n=9 gap=2 i=5 j=3
11. n=9 gap=2 i=6 j=4  12 2 12 19 20 30 28 42 35
12. n=9 gap=2 i=6 j=2
13. n=9 gap=2 i=7 j=5
14. n=9 gap=2 i=8 j=6
15. n=9 gap=1 i=1 j=0  2 12 12 19 20 30 28 42 35
16. n=9 gap=1 i=1 j=-1
17. n=9 gap=1 i=2 j=1
18. n=9 gap=1 i=3 j=2
19. n=9 gap=1 i=4 j=3
20. n=9 gap=1 i=5 j=4
21. n=9 gap=1 i=6 j=5  2 12 12 19 20 28 30 42 35
22. n=9 gap=1 i=6 j=4
23. n=9 gap=1 i=7 j=6
24. n=9 gap=1 i=8 j=7  2 12 12 19 20 28 30 35 42
25. n=9 gap=1 i=8 j=6
MinToMax array:		2 12 12 19 20 28 30 35 42

為了更好地查看當(dāng)前值,我將每一次交換的值用下劃線進(jìn)行標(biāo)出。

希爾排序(Shell sort)也稱“縮小增量排序”。它的做法不是每次一個(gè)元素挨一個(gè)元素的比較。而是先將整個(gè)待排記錄序列分割成為若干子序列分別進(jìn)行直接插入排序,待整個(gè)序列中的記錄基本有序時(shí),再對(duì)全體記錄進(jìn)行一次直接插入排序。這樣大大減少了記錄移動(dòng)次數(shù),提高了排序效率。
算法思路:先取一個(gè)正整數(shù)d1(d1<n),把全部記錄分成d1個(gè)組,所有距離為dl的倍數(shù)的記錄看成是一組,然后在各組內(nèi)進(jìn)行插入排序;接著取d2(d2<d1),重復(fù)上述分組和排序操作;直到di=1 (i>=1),即所有記錄成為一個(gè)組為止。希爾排序?qū)υ隽啃蛄械倪x擇沒有嚴(yán)格規(guī)定,一般選d1約為n/2,d2為d1/2,d3為d2/2,…,di=1。

posted on 2008-08-17 04:05 volnet 閱讀(9106) 評(píng)論(4)  編輯 收藏 引用

評(píng)論

# re: 希爾排序(Shell sort)排序算法 2008-08-17 12:04 u2usoft

圖片看不到  回復(fù)  更多評(píng)論   

# re: 希爾排序(Shell sort)排序算法 2008-08-17 17:37 dell筆記本

雖然很古老,但是很經(jīng)典。  回復(fù)  更多評(píng)論   

# re: 希爾排序(Shell sort)排序算法 2008-08-17 18:47 踏雪赤兔

始終未弄明白為什么這么多人對(duì)shell排序感興趣~~正如沒弄明白為什么這么多人對(duì)冒泡排序感興趣一樣……  回復(fù)  更多評(píng)論   

# re: 希爾排序(Shell sort)排序算法[未登錄] 2008-08-17 19:27 niino

冒泡排序的名字是如何來的呢...
  回復(fù)  更多評(píng)論   


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


特殊功能
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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热免费精品| 亚洲一区二区三区在线| 亚欧成人精品| 久久一区精品| 亚洲国产精品成人一区二区| 嫩草影视亚洲| 亚洲精品激情| 亚洲欧美在线另类| 免费黄网站欧美| 国产精品久久激情| 激情五月婷婷综合| 中文日韩欧美| 老司机精品久久| 99伊人成综合| 久久精品国产99精品国产亚洲性色 | 亚洲综合精品自拍| 午夜视频一区在线观看| 久久精品99国产精品酒店日本| 巨乳诱惑日韩免费av| 亚洲精品乱码久久久久久久久 | 久久国产精品99国产精| 欧美顶级大胆免费视频| 国产精品久久久久久久浪潮网站| 韩国视频理论视频久久| 亚洲少妇自拍| 亚洲国产美国国产综合一区二区| 亚洲欧美国产另类| 欧美精品1区2区| 一区精品在线播放| 亚洲欧美日韩一区二区三区在线观看| 久热精品视频在线| 亚洲一区999| 欧美精品七区| 在线播放日韩专区| 久久久久久9| 99re热这里只有精品视频 | 欧美一区二区三区四区夜夜大片 | 国产午夜精品久久| 一本大道久久精品懂色aⅴ| 久久色中文字幕| 亚洲欧美日韩一区二区在线 | 乱码第一页成人| 国产一区二区久久精品| 西西裸体人体做爰大胆久久久| 亚洲黑丝在线| 欧美1区3d| 亚洲欧洲精品一区二区三区不卡 | 国产精品日韩在线播放| 亚洲精选中文字幕| 亚洲高清二区| 欧美成人a∨高清免费观看| 在线播放精品| 欧美电影打屁股sp| 久久综合久久美利坚合众国| 国内精品免费午夜毛片| 久久精品国产清高在天天线 | 亚洲欧洲一二三| 欧美不卡视频一区发布| 亚洲人人精品| 激情久久久久久久| 国产在线视频欧美| 久久久999精品视频| 亚洲影视九九影院在线观看| 国产精品久久久久影院亚瑟| 国产精品99久久久久久宅男 | 亚洲国产精品激情在线观看| 久久久免费精品| 亚洲福利视频专区| 欧美顶级少妇做爰| 欧美极品在线视频| 亚洲免费婷婷| 欧美在线观看一二区| 在线观看欧美一区| 亚洲精品欧美极品| 国产精品激情av在线播放| 久久精品国产第一区二区三区最新章节 | 日韩视频―中文字幕| 国产精品盗摄一区二区三区| 欧美一区二区三区成人| 久久久久国产精品人| 日韩午夜在线播放| 香港久久久电影| 亚洲国产精品一区二区www在线| 亚洲国产老妈| 国产精品永久在线| 牛夜精品久久久久久久99黑人| 欧美国产精品日韩| 欧美一级视频精品观看| 久久人人97超碰精品888| aa级大片欧美| 久久精品视频在线播放| 99国产精品99久久久久久| 亚洲免费综合| 亚洲人成77777在线观看网| 在线亚洲免费| 亚洲国产黄色片| 亚洲综合日韩| 一区二区三区日韩在线观看| 翔田千里一区二区| 亚洲精品自在久久| 久久国产高清| 亚洲欧美国产制服动漫| 欧美激情一区二区| 久久久久国产精品厨房| 欧美午夜不卡在线观看免费| 可以看av的网站久久看| 国产精品你懂得| 99视频热这里只有精品免费| 在线免费高清一区二区三区| 在线综合视频| 日韩天堂在线观看| 欧美专区福利在线| 午夜一区在线| 欧美视频在线视频| 亚洲国产精品尤物yw在线观看 | 久久久精品国产一区二区三区| 亚洲国产精品久久久久婷婷老年| 一区二区免费在线播放| 亚洲高清不卡在线| 久久激情视频免费观看| 午夜日韩视频| 国产精品久久激情| 国产精品99久久不卡二区| 夜夜嗨av一区二区三区网站四季av| 久久人人97超碰国产公开结果| 久久久久久久999| 国产一区二区成人久久免费影院| 亚洲一区二区三区高清| 99热免费精品在线观看| 欧美久久久久久久| 亚洲精品偷拍| 亚洲一品av免费观看| 欧美日韩在线观看一区二区| 亚洲人成网站色ww在线 | 久久久亚洲国产美女国产盗摄| 国产精品一区二区三区四区五区 | 欧美精品日韩精品| 亚洲激情啪啪| 一二三区精品| 国产精品v欧美精品v日韩精品| 亚洲精品你懂的| 亚洲免费观看高清完整版在线观看熊 | 欧美一区二区精美| 久久婷婷成人综合色| 国内精品伊人久久久久av影院| 久久精品成人一区二区三区蜜臀| 久久久青草青青国产亚洲免观| 国产一区二区av| 老鸭窝91久久精品色噜噜导演| 欧美大片免费久久精品三p | 欧美精品三级日韩久久| 亚洲黄色精品| 香蕉乱码成人久久天堂爱免费 | 欧美日韩国产一区| 亚洲一区二三| 欧美不卡激情三级在线观看| 99re在线精品| 国产性猛交xxxx免费看久久| 久久久无码精品亚洲日韩按摩| 亚洲成色777777女色窝| 亚洲视频一区二区在线观看| 国产精品爽爽爽| 美女视频网站黄色亚洲| 在线一区视频| 欧美肥婆bbw| 亚洲欧美日韩国产另类专区| 国产自产高清不卡| 欧美精品成人一区二区在线观看| 亚洲午夜激情在线| 蜜臀久久久99精品久久久久久| 久久久久久亚洲综合影院红桃| 午夜精品999| 亚洲高清av在线| 国产精品一二三视频| 久久综合狠狠| 亚洲在线国产日韩欧美| 欧美激情中文字幕在线| 欧美在线观看天堂一区二区三区| 亚洲国产第一页| 国产精品一卡| 欧美四级在线观看| 免费永久网站黄欧美| 亚洲一区精彩视频| 亚洲二区视频在线| 久久精品亚洲精品| 亚洲综合精品一区二区| 亚洲欧洲精品一区二区三区| 国产亚洲精品久久久久婷婷瑜伽| 欧美国产视频在线| 久久久久久久尹人综合网亚洲| 日韩视频不卡中文| 欧美大色视频| 免费欧美日韩| 久久躁日日躁aaaaxxxx| 欧美伊久线香蕉线新在线| 亚洲无线视频|