排序算法:希尔排序

简介: 希尔排序法(缩小增量法) 属于插入类排序,是将整个无序列分割成若干小的子序列分别进行插入排序的方法。 //shell排序/*基本思想:将序列分成几类,在类里将它分成几个小组,再让它在小组内进行排序,依次重复直至排序成功1,找出间距gap(分类)最后间距分类必须为1...

希尔排序法(缩小增量法) 属于插入类排序,是将整个无序列分割成若干小的子序列分别进行插入排序的方法。
//shell排序

/*

  • 基本思想:将序列分成几类,在类里将它分成几个小组,再让它在小组内进行排序,依次重复直至排序成功

  • 1,找出间距gap(分类)最后间距分类必须为1, 第一重循环

  • 2, 找出各组 ,组间循环,第二重循环

  • 3,找出组内元素,第三重循环,并对转储

*/

#include <stdio.h>
void shellsort(int a[],int n)
{
    int i,j,flag,gap=n;
    int tmmp;
    while(gap>1)
    {
        gap=gap/2;//缩小增量,每次减半
        do//子序列应用冒泡排序
        {
            flag=0;
            for(i=0; i<n-gap; i++)
            {
                j=i+gap;
                if(a[i]<a[j])
                {
                    a[i]=a[i]^a[j];
                    a[j]=a[i]^a[j];
                    a[i]=a[i]^a[j];
                    flag=1;
                }
            }

        }
        while(flag!=0);//优化冒泡排序
    }
}

main()
{
    int i,a[10] = {-12,23,345,1,34,-45,34,3,2,5};
    printf("原序列的元素排序为:\n");
    for(i=0; i<10; i++)
    {
        printf("%d ",a[i]);

    }
    shellsort(a,10);

    printf("\n排序后的元素位置:");
    for(i=0; i<10; i++)
    {
        printf("%d ",a[i]);

    }

}
目录
相关文章
|
5月前
|
算法 搜索推荐 Java
数据结构与算法(Java篇)笔记--希尔排序
数据结构与算法(Java篇)笔记--希尔排序
|
4月前
|
算法 搜索推荐
数据结构算法--6 希尔排序和计数排序
**希尔排序**是插入排序的改进版,通过分组插入来提高效率。它逐步减少元素间的间隔(增量序列),每次对每个间隔内的元素进行插入排序,最终增量为1时进行最后一次直接插入排序,实现整体接近有序到完全有序的过程。例如,对数组`5, 7, 4, 6, 3, 1, 2, 9, 8`,先以间隔`d=4`排序,然后`d=2`,最后`d=1`,完成排序。计数排序则适用于0到100的数值,通过统计每个数出现次数,创建对应计数数组,再根据计数重建有序数组,时间复杂度为`O(n)`。
|
3月前
|
算法 搜索推荐 Shell
|
4月前
|
人工智能 搜索推荐 JavaScript
心得经验总结:排序算法:插入排序法(直接插入法和希尔排序法)
心得经验总结:排序算法:插入排序法(直接插入法和希尔排序法)
27 0
|
4月前
|
机器学习/深度学习 搜索推荐 算法
【C/排序算法】:直接插入排序和希尔排序
【C/排序算法】:直接插入排序和希尔排序
33 0
|
4月前
|
搜索推荐
排序算法---希尔排序---详解&&代码
排序算法---希尔排序---详解&&代码
|
4月前
|
算法 Shell C语言
数据结构与算法——希尔排序(引例、希尔增量序列、原始希尔排序、代码、时间复杂度、Hibbard增量序列、Sedgewick增量序列)
数据结构与算法——希尔排序(引例、希尔增量序列、原始希尔排序、代码、时间复杂度、Hibbard增量序列、Sedgewick增量序列)
41 0
|
5月前
|
存储 算法 搜索推荐
【数据结构与算法】:插入排序与希尔排序
欢迎大家来到初阶数据结构的最后一小节:排序
【数据结构与算法】:插入排序与希尔排序
|
5月前
|
搜索推荐 算法 Shell
【数据结构与算法】直接插入排序和希尔排序
【数据结构与算法】直接插入排序和希尔排序
|
5月前
|
算法 前端开发 搜索推荐
前端算法之希尔排序
前端算法之希尔排序
26 0
下一篇
无影云桌面