插入排序&希尔排序(C/C++)

插入排序:

复制代码
int main(void)
{

    int beauties[] = { 2, 1, 4, 6, 8, 5, 9, 7, 5 };
    int len = sizeof(beauties) / sizeof(beauties[0]);

    int preindex = 0, current = 0;

    for (int i = 1; i < len; i++)
    {
        preindex = i - 1;
        current = beauties[i];

        while (preindex >= 0 && beauties[preindex] > current)
        {
            beauties[preindex+1] = beauties[preindex ];
            preindex--;
        }
        beauties[preindex + 1] = current;
    }

    for (int i = 0; i < len; i++)
    {
        cout << beauties[i] << endl;
    }
    return 0;
}
复制代码

希尔排序:

复制代码
int main(void)
{
    int beauties[] = { 163, 161, 158, 165, 171, 170, 163, 1, 2 };
    int len = sizeof(beauties) / sizeof(beauties[0]);

    int gap = len / 2;
    for (; gap > 0; gap = gap / 2)
    {
        for (int i = gap; i < len; i++)
        {
            int current = beauties[i];
            int j = 0;
            for (j = i - gap; j >= 0 && beauties[j] > current; j -= gap)
            {
                beauties[j + gap] = beauties[j];
            }
            beauties[j + gap] = current;
        }
    }


for (int i = 0; i < len; i++)
    {
        cout << beauties[i] << endl;
    }
    return 0;
}
复制代码

 

posted @   乐吴  阅读(34)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示