• <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>

            elva

            shellsort之三


            網(wǎng)站: JavaEye  作者: shenyu  鏈接: http://shenyu.javaeye.com/blog/189563  發(fā)表時(shí)間: 2008年05月05日

            聲明:本文系JavaEye網(wǎng)站發(fā)布的原創(chuàng)博客文章,未經(jīng)作者書(shū)面許可,嚴(yán)禁任何網(wǎng)站轉(zhuǎn)載本文,否則必將追究法律責(zé)任!

            插入排序 對(duì)基本有序的數(shù)組效果非常好,但是對(duì)于通常情況則表現(xiàn)一般。假設(shè)最小的數(shù)字在最右邊,升序排序時(shí),這個(gè)數(shù)則要經(jīng)過(guò)n次交換比較換到最左邊。希爾排序則是對(duì)插入排序的很好的修正。而且在希爾排序很少出現(xiàn)最壞狀況。

            希爾排序通過(guò)對(duì)數(shù)組 以一定間隔相隔的位置 進(jìn)行插入排序,以達(dá)到讓數(shù)據(jù)快速出現(xiàn)在它應(yīng)該出現(xiàn)的位置的周?chē)箶?shù)組逐步接近基本有序。隨著間隔的減少,數(shù)組越來(lái)越接近基本有序,最后間隔為1時(shí),變成標(biāo)準(zhǔn)的插入排序。

            數(shù)據(jù)的間隔有多種算法,一般要求間隔序列之間互質(zhì),此處使用Kunth序列:h = h * 3 + 1

            希爾排序的時(shí)間效率很難從理論上證明,實(shí)驗(yàn)表明大約是O(n^(3/2)) ~ O(n^(7/6))之間。

            代碼如下:

            class Shell {
            public static void main(String[] args) {
            int[] a = {9,8,7,6,5,4,3,2,1};
            sort(a);
            println(a);
            }
            private static void println(int[] a) {
            for(int i: a) System.out.print(i + " ");
            System.out.println();
            }
            private static void sort(int[] a) {
            int h = 1;
            while(h <= a.length/3) h = h * 3 + 1;	//產(chǎn)成Kunth序列
            while(h > 0) {
            for(int i = h; i < a.length; i++) {	//對(duì)每個(gè)數(shù)據(jù)進(jìn)行間隔為h的插入排序
            int pos = i;
            int temp = a[i];
            while(pos >= h && a[pos - h] > temp) {
            a[pos] = a[pos-h];
            pos -= h;
            }
            a[pos] = temp;
            }
            h = (h - 1) / 3;	//減小間隔值
            }
            }
            }
             

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

            久久久久久极精品久久久| 人妻精品久久久久中文字幕一冢本| 国产韩国精品一区二区三区久久| 久久久久夜夜夜精品国产| 欧美日韩精品久久久免费观看| 亚洲国产另类久久久精品小说| 色综合色天天久久婷婷基地| 亚洲人成电影网站久久| 国产产无码乱码精品久久鸭| 亚洲精品99久久久久中文字幕 | 国产福利电影一区二区三区,免费久久久久久久精| 国产一级持黄大片99久久| 女人高潮久久久叫人喷水| 久久被窝电影亚洲爽爽爽| 久久亚洲AV成人出白浆无码国产| 久久狠狠一本精品综合网| 潮喷大喷水系列无码久久精品| 久久久久人妻一区二区三区| 久久亚洲国产成人影院网站| 久久久国产精品网站| 久久精品中文无码资源站| 7777精品久久久大香线蕉| 久久一区二区三区免费| 国产综合免费精品久久久| 亚洲国产二区三区久久| 国产精品美女久久久| 久久亚洲AV成人无码电影| 久久综合亚洲欧美成人| 亚洲伊人久久精品影院| 东方aⅴ免费观看久久av| 久久午夜无码鲁丝片秋霞| 亚洲精品无码久久不卡| 人妻无码αv中文字幕久久琪琪布| 久久国产香蕉视频| 免费精品国产日韩热久久| 一本色道久久88综合日韩精品 | AV狠狠色丁香婷婷综合久久 | 久久久久亚洲AV成人网| 久久五月精品中文字幕| 亚洲国产精品综合久久网络| 性做久久久久久久久浪潮|