标题:几种排序算法效率比较
取消只看楼主
long0042
Rank: 2
等 级:论坛游民
帖 子:38
专家分:50
注 册:2008-3-5
结帖率:100%
已结贴  问题点数:20 回复次数:5 
几种排序算法效率比较
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <conio.h>

#define NUM 1024*10

void swap(int *p, int *q)
{
    int tmp = *p;
    *p = *q;
    *q = tmp;
}

//////////////////选择排序///////////////////
void selectSort(int *p, int num)
{
    for (int i = 0; i < num; i++)
    {
        int min = p[i];
        int minindex = i;

        for (int j = i; j < num; j++)
        {
            if (min > p[j])
            {
                min = p[j];
                minindex = j;
            }
        }

        swap(&p[minindex], &p[i]);
    }
}
////////////////////////////////////////////////


///////////////////快速排序/////////////////////
int getSort(int *p, int min, int max)
{
    int i = min;
    int j = max;
    int key = p[min];

    while (1)
    {
        for (; ; j--)
        {
            if (i == j)
                return i;

            if (p[j] < key)
            {
                swap(&p[i], &p[j]);
                i++;
                break;
            }
        }

        for (; ; i++)
        {
            if (i == j)
                return i;

            if (p[i] > key)
            {
                swap(&p[i], &p[j]);
                j--;
                break;
            }
        }
    }

    return -1;
}

void quickSort(int *p, int min, int max)
{
    if (min >= max)
        return ;

    int i = getSort(p, min, max);
    if (i < 0)
        return ;

    quickSort(p, min, i-1);
    quickSort(p, i+1, max);
}

void quickSort2(int *p, int min, int max)
{
    if (min >= max)
        return ;

    int i = min;
    int j = max;
    int key = (p[min]+p[min+1])/2;
    int iIndex = i, jIndex = j;

    while (1)
    {
        if (i == j)
            break;

        for (;; j--)
        {
            if (p[j] < key)
            {
                iIndex = j;
                break;
            }
            if (i == j)
                break;
        }

        for (;; i++)
        {
            if (p[i] >= key)
            {
                jIndex = i;
                swap(&p[jIndex], &p[iIndex]);
                break;
            }
            if (i == j)
                break;
        }
    }

    quickSort2(p, min, i);
    quickSort2(p, i+1, max);
}
///////////////////////////////////////////////


///////////////////堆排序//////////////////////
void dealHeap(int *p, int index, int count)
{
    if (2*index + 2 > count)
        return ;

    int left = 2*index + 1;
    int right = 2*index + 2;

    int m = p[left] > p[right] ? left : right;

    if (p[m] > p[index])
    {
        swap(&p[m], &p[index]);
        dealHeap(p, m, count);
    }
}

void createHeap(int *p, int count)
{
    for (int i = count; i >= 0; i--)
    {
        dealHeap(p, i, count);
    }
}

void heapSort(int *p, int count)
{
    createHeap(p, count);

    for (int i = count; i >= 0; i--)
    {        
        dealHeap(p, 0, i);
        if (i != 1)
            swap(&p[0], &p[i]);
    }
}
//////////////////////////////////////////////////////


void writeData(int *buffer)
{
    for (int i = 0; i < NUM; i++)
    {
        buffer[i] = rand()%20000 + 1;
    }

    FILE *fp = fopen("data.dat", "wb");
    fwrite(buffer, sizeof(int), NUM, fp);
    fclose(fp);
}

void readData(int *buffer)
{
    FILE *fp = fopen("data.dat", "rb");
    fread(buffer, sizeof(int), NUM, fp);
    fclose(fp);
}


void usageMessage()
{
    printf("1选择排序\n");
    printf("2快速排序\n");
    printf("3堆排序\n");
    printf("q退出\n");
}

int main()
{
    int *buffer = (int *)malloc(sizeof(int) * NUM);
    writeData(buffer);
    usageMessage();

    int over = 1;
    while (over)
    {
        readData(buffer);

        float start;
        switch(getche())
        {
        case '1':
            {
                start = clock()/1000.0f;
                selectSort(buffer, NUM);
                float end = clock()/1000.0f;
                printf("\t选择排序 using time: %f\n", end-start);
                break;
            };
        case '2':
            {
                start = clock()/1000.0f;
                quickSort(buffer, 0, NUM-1);
                float end = clock()/1000.0f;
                printf("\t快速排序 using time: %f\n", end-start);
                break;
            }
        case '3':
            {
                start = clock()/1000.0f;
                heapSort(buffer, NUM-1);
                float end = clock()/1000.0f;
                printf("\t堆排序 using time: %f\n", end-start);
                break;
            }
        case 'q':
            {
                //exit
                over = 0;
            }
        }
    }

    free(buffer);

    return 0;
}

1、通过三种算法的比较,当数据量大的时候,快速排序用时最短。数据量少的时候差别基本上不大。
2、这三种算法都不是很适合数据整体是顺序的情况、这个时候情况不理想。可以选择插入排序等来替换(有时间写一个测试一下)
3、从网上的理论上讲,堆排序在数据量很大的时候要优于快速排序。我这里堆排序总是稍微比快速排序慢一点点, 是不是堆排序写的有问题呢?

通过设置NUM宏的值来对数据量不同的情况进行测试。编译环境vs2008 + win7
搜索更多相关主题的帖子: 算法 1024 include 
2012-07-20 21:12
long0042
Rank: 2
等 级:论坛游民
帖 子:38
专家分:50
注 册:2008-3-5
得分:0 
貌似大家对这种东东没什么兴趣啊。呵呵
2012-07-25 16:00
long0042
Rank: 2
等 级:论坛游民
帖 子:38
专家分:50
注 册:2008-3-5
得分:0 
回复 5楼 zklhp
我知道,数据结构里面说了一大堆。但那毕竟是理论,在实践中是不一样的。
不同的编译器,不同的平台,不同的人写的代码和优化的方法,可能都会造成差异。
本来想看看又没有人有好的优化方法或者是指明我不足的地方。
网上还说堆排序大数据的时候比快速排序快呢,我怎么写不出来。我这里只能证明快速排序更好些。
2012-07-25 16:11
long0042
Rank: 2
等 级:论坛游民
帖 子:38
专家分:50
注 册:2008-3-5
得分:0 
前面标号为1,2,3,4,5分别为选择排序,快速排序,快速排序改进,我写的堆排序,pangding写的堆排序。

以下是随机数排序结果比较:
2       快速排序 using time: 0.062000
3       快速排序 using time: 0.078000
4       堆排序 using time: 0.140000
5       堆排序 using time: 0.078000
2       快速排序 using time: 0.063000
3       快速排序 using time: 0.079000
4       堆排序 using time: 0.139999
5       堆排序 using time: 0.078000
2       快速排序 using time: 0.063000
3       快速排序 using time: 0.078001
4       堆排序 using time: 0.141001
5       堆排序 using time: 0.077999
2       快速排序 using time: 0.062000
3       快速排序 using time: 0.078001
4       堆排序 using time: 0.139999
5       堆排序 using time: 0.093000
2       快速排序 using time: 0.062000
3       快速排序 using time: 0.078001
4       堆排序 using time: 0.141001
5       堆排序 using time: 0.077999
2       快速排序 using time: 0.063000
3       快速排序 using time: 0.078003
4       堆排序 using time: 0.141003
5       堆排序 using time: 0.077999

以下是对顺序数据进行排序结果比较:
3       快速排序 using time: 0.031000
4       堆排序 using time: 0.125000
5       堆排序 using time: 0.062000
3       快速排序 using time: 0.031000
4       堆排序 using time: 0.110000
5       堆排序 using time: 0.062000
3       快速排序 using time: 0.030999
4       堆排序 using time: 0.125000
5       堆排序 using time: 0.062000
3       快速排序 using time: 0.031000
4       堆排序 using time: 0.125000
5       堆排序 using time: 0.063000
3       快速排序 using time: 0.032000
4       堆排序 using time: 0.125000
5       堆排序 using time: 0.062000
3       快速排序 using time: 0.032000
4       堆排序 using time: 0.125000
5       堆排序 using time: 0.062000
3       快速排序 using time: 0.032001
4       堆排序 using time: 0.125000
5       堆排序 using time: 0.063000
3       快速排序 using time: 0.031998
4       堆排序 using time: 0.125000
5       堆排序 using time: 0.063000

嗯。 总的来说快速排序效果还是最好的,不过你写的堆排序从效率上讲比我的要好那么一些。
我可以顺便学习下你写的这个了。
2012-07-26 09:32
long0042
Rank: 2
等 级:论坛游民
帖 子:38
专家分:50
注 册:2008-3-5
得分:0 
回复 9楼 pangding
嗯。 你写的我懂了。思想一样,我用的是递归。你是迭代。这就是唯一的区别了。呵呵。
2012-07-26 09:51
long0042
Rank: 2
等 级:论坛游民
帖 子:38
专家分:50
注 册:2008-3-5
得分:0 
回复 12楼 pangding
是这样的。第一种快速排序在遇到顺序的时候,可能和数据量有关系, 当数据量达到一定程度的时候程序会崩掉。怀疑是栈空间被耗尽了。
你后面提到的从大到小的数据排序,或者是峰谷的那种数据,也测试了一下。第二种快速排序可以适应。缺点就是你说的,它的速度和数据有关系,不够稳定。 堆排序确实是要稳定很多,基本上对于每种数据没有变化。这个估计就是堆排序中,第一步创建初始堆的时候起到的作用。不管是何种数据,他都会先整理为一定规律的数据,后面都是用那么多次运算。所以比较稳定。
2012-07-26 16:48



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-373788-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.084274 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved