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


            網站: JavaEye  作者: shenyu  鏈接: http://shenyu.javaeye.com/blog/189563  發表時間: 2008年05月05日

            聲明:本文系JavaEye網站發布的原創博客文章,未經作者書面許可,嚴禁任何網站轉載本文,否則必將追究法律責任!

            插入排序 對基本有序的數組效果非常好,但是對于通常情況則表現一般。假設最小的數字在最右邊,升序排序時,這個數則要經過n次交換比較換到最左邊。希爾排序則是對插入排序的很好的修正。而且在希爾排序很少出現最壞狀況。

            希爾排序通過對數組 以一定間隔相隔的位置 進行插入排序,以達到讓數據快速出現在它應該出現的位置的周圍,使數組逐步接近基本有序。隨著間隔的減少,數組越來越接近基本有序,最后間隔為1時,變成標準的插入排序。

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

            希爾排序的時間效率很難從理論上證明,實驗表明大約是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;	//產成Kunth序列
            while(h > 0) {
            for(int i = h; i < a.length; i++) {	//對每個數據進行間隔為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 葉子 閱讀(420) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構

            久久天天躁狠狠躁夜夜2020一| 久久久久久免费一区二区三区| 狠狠人妻久久久久久综合蜜桃| 国产精品免费久久久久久久久 | 欧美久久亚洲精品| 色综合久久夜色精品国产| 中文精品99久久国产| 国内精品久久九九国产精品| 91精品国产91久久久久久蜜臀| 亚洲国产高清精品线久久 | 久久亚洲国产成人精品性色| 久久精品无码一区二区无码 | 国产韩国精品一区二区三区久久| 狠狠精品久久久无码中文字幕| 久久天天躁狠狠躁夜夜2020一 | 国产精品美女久久久久久2018| 亚洲狠狠综合久久| 久久精品国产2020| 99久久国产主播综合精品| 亚洲日本va中文字幕久久| 国产精品成人99久久久久91gav| 中文字幕无码精品亚洲资源网久久 | 日韩AV毛片精品久久久| 久久久青草青青亚洲国产免观| 久久国语露脸国产精品电影| 久久久久97国产精华液好用吗| 久久久无码一区二区三区| 人妻系列无码专区久久五月天| 国内精品伊人久久久久| 中文字幕无码精品亚洲资源网久久| 丁香久久婷婷国产午夜视频| 久久超碰97人人做人人爱| 久久无码高潮喷水| 久久婷婷午色综合夜啪| 久久久久人妻一区精品果冻| 国产亚洲精午夜久久久久久 | 精品午夜久久福利大片| 久久精品中文无码资源站| 亚洲愉拍99热成人精品热久久| 久久精品aⅴ无码中文字字幕不卡| 久久91精品国产91久|