Shell Sort 希尔排序

class ShellSort {

public:

    void sort(int * arr, int size);

};


#include "ShellSort.h"
#include <iostream>

void ShellSort::sort(int *arr, int size) {
    int step = 1;
    int decreaseFactor = 3;
    //计算出最优的其实步长,后面步长都会每次取三分之一
    while(step < size / decreaseFactor){
        step = decreaseFactor * step + 1;
    }

    while(step >= 1){
        for (int i = step; i < size; ++i) {
            for (int j = i; j >= step && arr[j] < arr[j - step]; j = j - step) {
                std::swap(arr[j], arr[j - step]);
            }

        }
        step = step / decreaseFactor;
    }





}




posted on 2020-09-03 19:22  mindSucker  阅读(162)  评论(0编辑  收藏  举报