C语言(6) - 各种排序算法的比较

主要测试代码:

int  main( void )
{
    PrintDesc();
    
// cal_time(p_func_arr, ARRAY_SIZE(p_func_arr));
    clock_t t_start;    /*  start time when test starts  */
    clock_t t_end;     
/*  end time when test ends  */

    t_start 
=  clock();  /*  get start time  */
    
int  k  =   0 ;
    
while  (k ++< ForTimes)
    {
        
int   * array  =  get_ran();
        Sort(array);
    }
    t_end 
=  clock();    /*  get end time  */
    printf(
" 数据量:%d ,循环次数:%d ,平均排序时间: %.3f s\n " , ArraySize,ForTimes,( double )(t_end - t_start) / (CLOCKS_PER_SEC * ForTimes));

    
return   0 ;
}

 测试结果:

1. 冒泡排序

----------  C￐L  ----------
[冒泡排序]
数据量:
1000  ,循环次数: 100  ,平均排序时间:  0.007  s

数据量:
10000  ,循环次数: 100  ,平均排序时间:  0.659  s

输出完成 (耗时: 0 秒) 

当测试100000数据量的时候就很慢了,我等到3分钟的时候已经等不下去了,直接CUTE掉了(因为这里是十万数据*100次循环==千万数据了)

冒泡排序是最慢的排序算法。在实际运用中它是效率最低的算法。它通过一趟又一趟地比较数组中的每一个元素,使较大的数据下沉,较小的数据上升。时间复杂度O(n2) 小数据量时使用。

 

 2.插入排序

----------  C￐L  ----------
[插入排序]
数据量:
1000   ,循环次数: 100  ,平均排序时间:  0.002  s

数据量:
10000  ,循环次数: 100  ,平均排序时间:  0.190  s
输出完成 (耗时: 
0  秒)

 时间复杂度O(n2),小数据量时使用。

 

3. 选择排序

 

  ---------- C￐L ----------

[选择排序]
数据量:  
1000  ,循环次数: 100  ,平均排序时间:  0.003  s

数据量: 
10000  ,循环次数: 100  ,平均排序时间:  0.282  s

输出完成 (耗时: 
0  秒)

 时间复杂度O(n2),小数据量时使用。

 

4. 快速排序

----------  C￐L  ----------
[快速排序]
数据量: 
10000  ,循环次数: 100  ,平均排序时间:  0.003  s

数据量:
100000  ,循环次数: 100  ,平均排序时间:  0.037  s

数据量:
1000000  ,循环次数: 100  ,平均排序时间:  0.420  s
输出完成 (耗时: 
0  秒)

 实际应用中用的最多的,也是最常见的一种排序方法,其主要思想是用了分治法

 时间复杂度O(nlogn)

 

5. 归并排序

----------  C￐L  ----------
[归并排序]
数据量: 
10000  ,循环次数: 100  ,平均排序时间:  0.005  s

数据量:
100000  ,循环次数: 100  ,平均排序时间:  0.056  s
输出完成 (耗时: 
0  秒)

 数据到达百万的时候会自己CUTE掉

 时间复杂度O(nlogn)

 C排序算法

 

转载于:https://www.cnblogs.com/uwebs/archive/2009/06/09/1499494.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值