• <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ā)表時間: 2008年05月05日

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

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

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

            數(shù)據(jù)的間隔有多種算法,一般要求間隔序列之間互質(zhì),此處使用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;	//產(chǎn)成Kunth序列
            while(h > 0) {
            for(int i = h; i < a.length; i++) {	//對每個數(shù)據(jù)進行間隔為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) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結構

            久久综合综合久久97色| AV无码久久久久不卡蜜桃| 99久久婷婷国产一区二区| 久久久99精品成人片中文字幕| 欧美亚洲另类久久综合婷婷 | 久久亚洲国产最新网站| 久久综合噜噜激激的五月天| 青青草国产精品久久| 伊人色综合久久天天人守人婷| 久久这里只有精品久久| 久久久久久精品成人免费图片| 国产精品一久久香蕉产线看| 亚洲国产精品无码久久青草 | 久久久噜噜噜久久| 国产一区二区三区久久精品| 99精品国产99久久久久久97| 久久91这里精品国产2020| 久久亚洲精品成人av无码网站 | 久久精品麻豆日日躁夜夜躁| 久久笫一福利免费导航| 久久精品国产精品亚洲| 国产成人无码精品久久久免费 | 伊人伊成久久人综合网777| 久久久久国色AV免费看图片| 老司机国内精品久久久久| 国内精品久久人妻互换| 久久夜色精品国产噜噜麻豆 | 久久久WWW成人免费毛片| 欧美综合天天夜夜久久| 久久综合九色综合97_久久久| 91视频国产91久久久| 久久夜色精品国产亚洲| 久久精品嫩草影院| 蜜桃麻豆www久久| 久久精品国产99国产电影网| 久久精品9988| 久久97久久97精品免视看秋霞| 久久精品中文字幕有码| 久久这里只有精品视频99| 漂亮人妻被中出中文字幕久久| 久久人人爽人人爽人人片av麻烦 |