国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

排序算法 之 希爾排序

2019-11-10 21:35:22
字體:
供稿:網(wǎng)友

原文地址http://www.cnblogs.com/liukemng/p/3723976.html

希爾排序是由D.L.Shell于1959年提出的,所以稱為希爾排序。希爾排序又稱縮小增量排序,是插入排序的一種改進(jìn)。

基本思想:希爾排序是基于插入排序的以下特點(diǎn):待排序的序列元素?cái)?shù)量越少排序速度越快;待排序序列的元素基本有序時排序速度越快;基于以上思想將待排序序列分為多個子序列分別進(jìn)行插入排序,然后減少子序列的個數(shù)重新進(jìn)行插入排序,重復(fù)以上過程,直至待排序的序列只有一個再進(jìn)行一次插入排序,則排序完成序列有序。

代碼實(shí)現(xiàn):

復(fù)制代碼
/// <summary>/// 希爾排序/// </summary>/// <param name="intArray"></param>/// <param name="length"></param>public static void ShellSort(int[] intArray, int length){    int gap, i, j, temp;    for (gap = length / 2; gap >= 1; gap = gap / 3+1)    {        for(i=gap;i<length;i++)        {            temp=intArray[i];            for(j=i-gap;j>=0&&intArray[j]>temp;j-=gap)                intArray[j+gap]=intArray[j];            intArray[j+gap]=temp;        }        if(gap==1)            break;    }}復(fù)制代碼

需說明的是不同的間隔gap選擇會對排序的效率有不同的影響,且不容易確定最佳的間隔gap,感興趣的朋友可以搜索相關(guān)資料作為參考。

以上就是希爾排序的內(nèi)容。


上一篇:File類的用法

下一篇:最長上升子序列

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 当雄县| 门头沟区| 容城县| 济阳县| 海伦市| 玛沁县| 云南省| 兴城市| 湄潭县| 克什克腾旗| 新龙县| 隆化县| 东至县| 太康县| 西华县| 仁怀市| 温宿县| 泾阳县| 沙坪坝区| 屯门区| 堆龙德庆县| 沾化县| 张家口市| 宿松县| 张家界市| 嵩明县| 灌云县| 红河县| 高淳县| 灵山县| 清涧县| 沐川县| 楚雄市| 绥宁县| 海原县| 行唐县| 婺源县| 安福县| 横峰县| 新野县| 石门县|