插入排序与希尔排序

如果你要学希尔排序,那就一定要先学会直接插入排序。

1.插入排序

单趟实现:

int end = 0;
int tmp = a[end + 1];
while (end >= 0)
{
    if (a[end] > tmp)
    {
        a[end + 1] = a[end];
        end--;
    }
    else
    {
        break;
    }
    a[end + 1] = tmp;//此刻的end+1实际上是原来end的值,因为end--
}

具体思路就是通过设end来将两个数字相互比较,互换位置实现顺序,tmp为临时变量防止数据丢失。

循环实现:

    for (int i = 0; i < n - 1; i++)//i的范围是n-1的原因是end+1<n
    {
        int end = i;
        int tmp = a[end + 1];
        while (end >= 0)
        {
            if (a[end] > tmp)
            {
                a[end + 1] = a[end];
                end--;
            }
            else
            {
                break;
            }
            a[end + 1] = tmp;
        }
    }
对比单趟,我们发现添加了两个循环,以及开头对end的赋值变为了int end = i;

while循环实现的是一串数字之间的两两比较

for循环实现了让end不再遍历之前已排好的数字,节省了时间

2.希尔排序

希尔排序的思路即将一个数组中的数分成若干组,再将每组按照插入排序的方式排为顺序。

分组的方式采用将每隔gap(自定义)个数的数字取出组为一组,再不断减小gap直至为1————此时相当于进行直接插入排序,但这时的数组已十分接近有序。

下面是代码实现:

首先赋值gap为n,再逐渐减小,就好比在炒一锅菜,先大火爆炒(让整体框架变得有序),再文火慢炖(确保每个数字都能有序)。

代码其实很简单,只是将插入排序中所有的1gap替代后,再嵌套一个关于gap的循环。

但这个思想其实很抽象,平时要尽量多去理解,争取做到不写插入,直接写希尔一遍过!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值