【排序】希尔排序,C++实现

原创博文,转载请注明出处!

本文代码的github地址

# 基本思路

      希尔排序是”直接插入排序“的改进版,也称为“缩小增量排序”。基本原理:先将待排序的数组元素分成多个序列,然后对每个子序列分别进行直接插入排序,最后再对所有元素进行一次直接插入排序。

1024555-20161128110416068-1421707828

# C++代码

#include<iostream>
#include<vector>
using namespace std;
void ShellSort(vector<int>vec)
{
		// 希尔排序
    for(int gap=vec.size()/2;gap>0;gap/=2)
    {
				// 直接插入排序 
        for(int i=gap;i<vec.size();++i)
        {
            int j=i;
            while(j-gap>=0 && vec[j-gap]>vec[j])
            {
                vec[j-gap] = vec[j-gap]+vec[j];
                vec[j]     = vec[j-gap]-vec[j];
                vec[j-gap] = vec[j-gap]-vec[j];
                j=j-gap;
            }
        }
    }
		
		// 打印输出
    for(int i=0;i<vec.size();++i)
    {
        cout<<vec[i]<<endl;
    }

}
int main()
{
    vector<int> vec={8,9,1,7,2,3,5,4,6,0};
    ShellSort(vec);
    return 0;
}
posted @ 2018-04-06 12:26  wanglei5205  阅读(2884)  评论(0编辑  收藏  举报
levels of contents