文档章节

常用排序算法(二)

eatnothing
 eatnothing
发布于 2016/02/16 10:49
字数 531
阅读 38
收藏 1

####希尔排序

  • 时间复杂度:
  • 空间复杂度:
  • method:将需要排序的的序列划分为若干个较小的序列,对这些序列进行直接插入排序.
void shellsort(int A[],int n);
void shellsort(int A[],int n){

    int d,i,x,j;
    d = n /2 ;
    while(d>=1){
        for(i =d ;i<n;i++){
            x = A[i];
            j = i-d;
            while (j>=0&&A[j]>x) {
                A[j+d] = A[j];
                j = j -d;
            }
            A[j+d] = x;
        }
        d = d /2;
    }   
}
int main(int argc, const char * argv[]) {
    // insert code here...
    int A[9] = {12,34,54,2,1,4,3,5,6};
    shellsort(A, 9);

    for(int i = 0;i<9;i++){
        printf("%d",A[i]);
    }
    return 0;
}

####堆排序法

  • 堆是一个完全二叉树,首先
  • 1:将无序的数据构成堆,(既用无序的数据生成满足堆定义的完全二叉树)
  • 2:利用堆排序,(既将上一步生成的堆输出,得到排序后的有序数据)
  • 时间复杂度:o(nlog2^n)
  • 空间复杂度:o(1)
void HeapAdjust(int A[] , int s ,int n){
    int j,t;
    while(2*s+1<n){
        j = 2*s +1;
        if((j+1)<n){
            if(A[j]<A[j+1])
                j++;
        }
        if(A[s]<A[j]){
            t    = A[s];
            A[s] = A[j];
            A[j] = t;
            s = j;
        }else break;

    }

}
void HeapSort(int A[],int  n){

    int t ,i;
    int j;
    for(i = n / 2 -1;i >= 0; --i){
        HeapAdjust(A,i,n);
    }
    for(i = n - 1;i > 0;i--){
        t    = A[0];
        A[0] = A[i];
        A[i] = t;
        HeapAdjust(A,0,i);

    }

}

####桶排序

  • 桶排序是稳定的
  • 桶排序是常见排序里最快的一种,比快排还要快…大多数情况下
  • 桶排序非常快,但是同时也非常耗空间,基本上是最耗空间的一种排序算法
//获得桶排序的MAX值
int GetMaxVal(int * arr,int len){

    int maxVal = arr[0];
    for(int i = 1; i<len;i++){
        if(arr[i]>maxVal){
            maxVal = arr[i];
        }

    }
    return maxVal;
}
void BucketSort(int * arr,int len){
    int tempArrlen = GetMaxVal(arr, len)+1;
    int tempArr[tempArrlen];    //获得空桶大小
    int i,j;
    for(i =0;i<tempArrlen;i++){     //空桶初始化
        tempArr[i] = 0;
    }
    for(i = 0;i<len;i++){
        tempArr[arr[i]]++;
    }
    for(i=0,j=0;i<tempArrlen;i++){

        while(tempArr[i]!=0){
            arr[j] = i;
            j++;
            tempArr[i]--;

        }
    }

}
int main(int argc, const char * argv[]) {
    // insert code here...

    int A[10] = {3,123,4,4,1,23,534,21,12,4};

    BucketSort(A, 10);

    for(int i =0;i<10;i++){

        printf("%d,",A[i]);
    }
    printf("Hello, World!\n");
    return 0;
}

© 著作权归作者所有

共有 人打赏支持
eatnothing
粉丝 37
博文 128
码字总数 68736
作品 0
昌平
程序员
私信 提问
各种基本算法实现小结(六)—— 查找算法

各种基本算法实现小结(六)—— 查找算法 (均已测试通过) =================================================================== 1、简单查找 在一组无序数列中,查找特定某个数值,并返...

长平狐
2013/01/06
75
0
java排序之快速排序、归并排序、基数排序

前两篇说了Java排序中的冒泡、选择、插入、希尔等排序算法,今天就探讨一下剩下的三种常用排序。 快速排序: 当要求时间最快时,就可以用快速排序算法。 选择第一个数为p,小于p的数放在左边...

野小疯
06/05
0
0
常用数据结构以及数据结构的排序算法

数组 (Array)   在程序设计中,为了处理方便, 把具有相同类型的若干变量按有序的形式组织起来。这些按序排列的同类数据元素的集合称为数组。在C语言中, 数组属于构造数据类型。一个数组可...

带梦想一7飞
2012/09/13
0
0
涨姿势,图文带你了解 8 大排序算法

排序算法可以分为内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的排序记录,在排序过程中需要访问外存。 常见的内部排序算法有...

Java架构
07/25
0
0
维基百科上的算法和数据结构链接很强大

突然发现维基百科上的算法和数据结构比百度百科强多啦,图文并茂。 其实这个网站不错:http://www.sorting-algorithms.com 冒泡排序: bubble冒泡的意思 http://zh.wikipedia.org/wiki/%E5%8...

晨曦之光
2012/03/09
2.3K
1

没有更多内容

加载失败,请刷新页面

加载更多

MariaDB 服务器在 MySQL Workbench 备份数据的时候出错如何解决

服务器是运行在 MariaDB 10.2 上面的,在使用 MySQL Workbench 出现错误: mysqldump: Couldn't execute 'SELECT COLUMN_NAME, JSON_EXTRACT(HISTOGRAM, '$."number-of-buckets-specified"'......

honeymose
今天
3
0
apache顶级项目(二) - B~C

apache顶级项目(二) - B~C https://www.apache.org/ Bahir Apache Bahir provides extensions to multiple distributed analytic platforms, extending their reach with a diversity of s......

晨猫
今天
6
0
day152-2018-11-19-英语流利阅读

“超级食物”竟然是营销噱头? Daniel 2018-11-19 1.今日导读 近几年来,超级食物 superfoods 开始逐渐走红。不难发现,越来越多的轻食餐厅也在不断推出以超级食物为主打食材的健康料理,像是...

飞鱼说编程
今天
14
0
SpringBoot源码:启动过程分析(二)

接着上篇继续分析 SpringBoot 的启动过程。 SpringBoot的版本为:2.1.0 release,最新版本。 一.时序图 一样的,我们先把时序图贴上来,方便理解: 二.源码分析 回顾一下,前面我们分析到了下...

Jacktanger
昨天
4
0
Apache防盗链配置,Directory访问控制,FilesMatch进行访问控制

防盗链配置 通过限制referer来实现防盗链的功能 配置前,使用curl -e 指定referer [root@test-a test-webroot]# curl -e "http://www.test.com/1.html" -x127.0.0.1:80 "www.test.com/1.jpg......

野雪球
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部