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

本文代码的github地址

# 基本思路

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

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

# 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;
}

相关文章:

  • 2022-03-04
  • 2021-11-05
  • 2021-07-07
  • 2022-12-23
  • 2021-07-22
  • 2022-01-06
  • 2021-08-09
猜你喜欢
  • 2022-01-06
  • 2021-09-29
  • 2021-05-16
  • 2021-08-20
  • 2021-11-11
  • 2022-01-17
  • 2022-12-23
相关资源
相似解决方案