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

MyMSDN

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

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

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

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

#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ù):按遞增順序對v[0]…v[n-1]進行排序*/
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');
}

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

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

為了更好地查看當前值,我將每一次交換的值用下劃線進行標出。

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

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

評論

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

圖片看不到  回復  更多評論   

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

雖然很古老,但是很經典。  回復  更多評論   

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

始終未弄明白為什么這么多人對shell排序感興趣~~正如沒弄明白為什么這么多人對冒泡排序感興趣一樣……  回復  更多評論   

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

冒泡排序的名字是如何來的呢...
  回復  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網站導航: 博客園   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>
            国产欧美欧洲在线观看| 久久亚洲私人国产精品va| 国产精品大全| 欧美日韩亚洲综合| 欧美日韩亚洲三区| 欧美在线高清| 日韩亚洲欧美一区| 久久精品久久99精品久久| 欧美一级片在线播放| 久久久久国产成人精品亚洲午夜| 久久久久久综合网天天| 欧美电影电视剧在线观看| 亚洲欧洲午夜| 在线视频一区二区| 欧美一级午夜免费电影| 久热国产精品| 国产精品久久久久久av下载红粉 | 国产精品亚洲综合久久| 国产专区综合网| 日韩视频在线播放| 午夜精品福利在线| 欧美成人亚洲| 亚洲主播在线| 欧美久久久久| 国产亚洲精品高潮| 99视频在线精品国自产拍免费观看| 亚洲综合99| 欧美电影在线免费观看网站| 亚洲亚洲精品在线观看| 美日韩丰满少妇在线观看| 国产精品久久久久久久浪潮网站 | 国产精品丝袜白浆摸在线| 亚洲高清不卡av| 欧美一区二区三区久久精品| 亚洲成色最大综合在线| 亚洲欧美精品伊人久久| 亚洲国产成人高清精品| 欧美在线免费视频| 最新亚洲视频| 欧美一区二区三区视频免费播放| 欧美韩日一区| 亚洲专区在线视频| 欧美日韩理论| 亚洲日本视频| 免费国产自线拍一欧美视频| 亚洲私人影院在线观看| 欧美日韩精品在线播放| 亚洲国产毛片完整版| 欧美一区二区三区免费观看视频| 一区二区激情视频| 欧美视频二区36p| 亚洲免费成人av| 欧美成人免费全部| 久久久久国产精品一区| 国产日本亚洲高清| 午夜精品影院| 亚洲欧美偷拍卡通变态| 国产精品国产三级国产aⅴ无密码| 亚洲精品一二三| 亚洲二区视频在线| 免费成人在线视频网站| 亚洲国产精品久久久久秋霞影院| 久热国产精品视频| 看片网站欧美日韩| 亚洲欧洲综合另类| 欧美日韩在线精品| 久久精品综合一区| 99亚洲一区二区| 亚洲天堂第二页| 欧美精品国产| 国产乱人伦精品一区二区| 亚洲视频精品在线| av不卡在线| 国产精品综合不卡av| 欧美亚洲免费高清在线观看| 亚洲综合国产精品| 久久久久久高潮国产精品视| 欧美午夜不卡视频| 亚洲精品中文字幕在线| 欧美国产精品| 日韩一级二级三级| 亚洲一区二区三区四区在线观看| 国产欧美一区二区三区视频| 久久婷婷国产综合精品青草| 久久女同精品一区二区| 亚洲欧洲日本mm| 日韩亚洲一区二区| 国产精品久久久久久久久搜平片 | 国产一区视频观看| 蜜桃av综合| 欧美日韩一区二区高清| 欧美特黄一级| 国产亚洲午夜高清国产拍精品| 久久综合狠狠综合久久综合88| 美女尤物久久精品| 亚洲一级在线观看| 欧美一级视频免费在线观看| 亚洲精品视频一区二区三区| 亚洲一级片在线观看| 亚洲高清成人| 亚洲视频自拍偷拍| 亚洲激情视频在线播放| 亚洲视频你懂的| 在线日韩av永久免费观看| 一区二区91| 在线成人av| 亚洲影院在线| 日韩图片一区| 久久激情综合网| 亚洲一区二区三区色| 久久色在线观看| 欧美一区午夜精品| 欧美日韩一区二区在线| 欧美成人在线免费观看| 国产精品亚洲人在线观看| 亚洲欧洲日本国产| 狠久久av成人天堂| 亚洲综合精品自拍| 亚洲一区二区三区免费观看 | 亚洲一区二区三区涩| 亚洲精品你懂的| 久久午夜电影网| 久久男女视频| 国产精品毛片a∨一区二区三区|国| 亚洲成色777777在线观看影院| 国产一区二区三区高清| 亚洲尤物精选| 亚洲欧美日韩综合国产aⅴ| 欧美精品性视频| 亚洲国产免费看| 亚洲美女精品久久| 欧美成人免费在线视频| 欧美激情片在线观看| 亚洲成在人线av| 久久久精品tv| 久久综合狠狠综合久久综青草| 国产精品影院在线观看| 午夜精品福利一区二区三区av| 亚洲欧美日韩中文视频| 国产精品视频免费观看| 亚洲天天影视| 欧美一区二区精品在线| 国产欧美1区2区3区| 亚洲女爱视频在线| 性欧美18~19sex高清播放| 国产欧美亚洲日本| 欧美在线亚洲在线| 久久综合狠狠综合久久综青草 | 欧美经典一区二区三区| 亚洲精品免费网站| 亚洲视频国产视频| 米奇777在线欧美播放| 久久久亚洲国产天美传媒修理工 | 麻豆精品视频| 亚洲高清激情| 欧美日韩视频在线一区二区| 夜夜爽www精品| 欧美影院在线| 一区国产精品| 欧美精品在线看| 亚洲桃色在线一区| 久久久亚洲午夜电影| 亚洲国产欧美一区| 欧美三级第一页| 欧美一区二区私人影院日本 | 午夜视频久久久久久| 国产曰批免费观看久久久| 久久男人av资源网站| 亚洲理论电影网| 小黄鸭精品密入口导航| 在线日本欧美| 国产精品成人在线| 久久免费偷拍视频| 夜夜精品视频| 久久另类ts人妖一区二区| 亚洲精品一区二区三区福利| 欧美午夜片在线免费观看| 午夜精品福利一区二区三区av| 欧美成人在线免费观看| 亚洲欧美日韩综合aⅴ视频| 亚洲福利视频二区| 国产精品久久一级| 久久综合伊人| 亚洲一区三区视频在线观看 | 欧美在线视频免费观看| 亚洲国产精品悠悠久久琪琪| 欧美性开放视频| 裸体丰满少妇做受久久99精品| 亚洲影视在线播放| 99热这里只有精品8| 农夫在线精品视频免费观看| 性8sex亚洲区入口| 99一区二区| 91久久综合| 国产一区亚洲一区| 国产精品久久久久永久免费观看| 免费毛片一区二区三区久久久| 欧美影院午夜播放| 亚洲欧美日韩中文播放| 99riav国产精品|