排序,可以对一组数据按升序或降序进行排序。本篇博客将介绍两种常见的排序算法:直接插入排序和希尔排序。
一、直接插入排序
直接插入排序是最简单的排序算法之一。该算法的思想是将待排序的序列插入到已经排序好的序列中。下面是该算法的详细步骤:
- 首先,我们将第一个元素视为已经排序好的序列。
- 然后,从第二个元素开始,依次将每个元素插入到已经排序好的序列中。
- 对于每个元素,我们将其与已经排序好的序列中的所有元素进行比较,将其插入到正确的位置。
以下是直接插入排序的C语言实现:
void InsertSort(int *a, int n)
{
int i, end, temp;
for (i = 1; i < n; i++)
{
end = i - 1;
temp = a[end + 1];
while (end >= 0 && a[end] < temp)
{
a[end + 1] = a[end];
end--;
}
a[end + 1] = temp;
}
}
其中,参数a代表待排序的序列,参数n
代表序列长度,temp代表当前需要插入的元素的值。在算法的每一次迭代中,我们将temp与已经排序好的元素进行比较,并根据需要移动已排序好的元素以便为temp腾出正确的位置。
该算法的时间复杂度为O(n^2)O(n2),因此适用于小规模数据的排序,而对于大规模数据的排序则不太适合。
二、希尔排序
希尔排序是一种改进的插入排序算法。与直接插入排序不同的是,希尔排序将待排序的序列划分为若干个子序列,对每个子序列进行插入排序,最后再对整个序列进行一次插入排序。以下是希尔排序的详细步骤:
- 首先,我们选择一个增量序列d_1, d_2, …, d_kd1,d2,…,dk,其中d_1 > d_2 > … > d_k = 1d1>d2>…>dk=1。
- 对于每个i=1,2,…,ki=1,2,…,k,我们将所有距离为d_idi的元素作为一个子序列,并对每个子序列进行插入排序。
- 最后,当增量为1时,我们对整个序列进行一次插入排序。
以下是希尔排序的C语言实现:
// 希尔排序
void ShellSort(int *a, int n)
{
int gap = 3;
int i, end, temp;
for (gap = n / 2; gap > 0; gap /= 2)
{
for (i = gap; i < n; i++)
{
end = i - gap;
temp = a[end + gap];
while (end >= 0 && a[end] < temp)
{
a[end + gap] = a[end];
end -= gap;
}
a[end + gap] = temp;
}
}
}
其中,gap
代表当前的增量。在算法的每一次迭代中,我们不断缩小gap,以达到排序的效果。
希尔排序的时间复杂度较为复杂,在O(n^2/3)到O(nlog^2n)之间。然而,由于其对大规模数据的排序效果良好,因此被广泛应用于各种实际场景中。
三、总结
直接插入排序和希尔排序都是基于插入排序的算法,它们的主要区别在于如何分组并进行排序。直接插入排序适用于小规模数据的排序,而希尔排序则可以处理大规模数据的排序。在实际应用中,我们可以根据需要选择合适的排序算法来提高程序的效率。