免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123456
最近访问板块 发新帖
楼主: 061107
打印 上一主题 下一主题

[算法] 任意个数里找出最大的前10个,欢迎大家一起来优化 [复制链接]

论坛徽章:
0
51 [报告]
发表于 2008-07-22 17:10 |只看该作者

46楼的算法并不优秀,你还得那么大的数组里找那10最大的。

int f( int *A; int count )
{
    // The last cell for temp strorage.
    int B[11];

    for( int i = 0; i < count; i++ )
    {
        int j = 0;
        if ( i < 10 )
        {
            B = A;
            j = i;
        }
        else
        {
            B[10] = A;
            j=10;
        }
        for( ; j > 0; j--)
        {
            if( B[j-1] < B[j] )
            {
                int x = B[j];
                B[j] = B[j-1];
                B[j-1] = x;
            }
            else
            {
            break;
            }
        }
    }
}

这个算法最差是O(m*n). 平均比较好像是对数时间的复杂度。研究生时做过这个题。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP