插入排序和希尔排序

排序,可以对一组数据按升序或降序进行排序。本篇博客将介绍两种常见的排序算法:直接插入排序和希尔排序。

一、直接插入排序

直接插入排序是最简单的排序算法之一。该算法的思想是将待排序的序列插入到已经排序好的序列中。下面是该算法的详细步骤:

  • 首先,我们将第一个元素视为已经排序好的序列。
  • 然后,从第二个元素开始,依次将每个元素插入到已经排序好的序列中。
  • 对于每个元素,我们将其与已经排序好的序列中的所有元素进行比较,将其插入到正确的位置。

以下是直接插入排序的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)之间。然而,由于其对大规模数据的排序效果良好,因此被广泛应用于各种实际场景中。

三、总结

直接插入排序和希尔排序都是基于插入排序的算法,它们的主要区别在于如何分组并进行排序。直接插入排序适用于小规模数据的排序,而希尔排序则可以处理大规模数据的排序。在实际应用中,我们可以根据需要选择合适的排序算法来提高程序的效率。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值