• 【排序】希尔排序,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;
    }
  • 相关阅读:
    POJ3164 Command Network
    UVa11401 Triangle Counting
    UVa11174 Stand in a Line
    UVa11806 Cheerleaders
    Uva11538 Chess Queen
    Bzoj3130 [Sdoi2013]费用流
    Bzoj3262 陌上花开
    模拟25A 题解
    模拟24 题解
    模拟23 题解
  • 原文地址:https://www.cnblogs.com/wanglei5205/p/8727377.html
Copyright © 2020-2023  润新知