关于希尔排序的见解(参考于挑战程序设计2)

关于希尔排序的见解(参考于挑战程序设计2)

所谓希尔排序,就是应用插入排序处理大数据排序的算法,插入排序可以高速处理顺序较为整齐的数据,而希尔排序正是发挥了插入排序的这一特性,通过希尔数组(可能是我自己起的名字),将无序的数,先排列的较为有序,再通过插入排序来达到对数据的排列的目的。

下面是代码

#include<iostream>
#include<cmath>
#include<vector>

using namespace std;

long long cnt;
int A[100000];
int n;
vector<int> G;

void insertionSort(int A[], int n, int g)
{
	for (int i = g; i < n; i++)
	{
		int v = A[i];
		int j = i - g;
		while (j >= 0 && A[j] > v)
		{
			A[j + g] = A[j];
			j -= g;
			cnt++;
		}
		A[j + g] = v;
	}
}

//生成希尔数列
void shellSort(int A[], int n)
{
	for (int h = 1;;)
	{
		if (h > n) break;
		G.push_back(h);  //在G的后面添加一个元素
		h = h * 3 + 1;
	}
	for (int i = G.size() - 1; i >= 0; i--)      //G.size()表示获取G的元素个数
	{
		insertionSort(A, n, G[i]);
	}
}


int main() 
{
	cin >> n;
	for (int i = 0; i < n; i++) scanf("%d", &A[i]);
	cnt = 0;

	shellSort(A, n);

	cout << G.size() << endl;
	for (int i = G.size() - 1; i >= 0; i--)
	{
		printf("%d", G[i]);
		if (i) printf(" ");
	}

	printf("\n");
	printf("%d\n", cnt);
	for (int i = 0; i < n; i++)
	{
		printf("%d \n", A[i]);
	}
}

代码分析

首先通过cin键入n的值,然后用for循环进行数据的读入。选用速度更快的scanf函数进行输入。
接着调用shellSort函数。

在shellSort函数中传入的是A的地址和A的长度。第一个for循环是用来生成希尔数组的。
h从1开始,用Vector的push_back函数将或添加到G的最后一项,当h大于n的时候跳出循环。希尔数列生成完毕。

接下来,第二个for循环循环调用insertionSort函数,将希尔数列中的数从后开始传入函数中。

接着在insertionSort中进行排序 。

  • 9
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

敲困难的代码猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值