n个数里面找出最大的m个数字(快排思想)

原创 2016年08月31日 10:05:13

分析:这个问题,我之前遇到的时候想到的解决方案是,最小堆解决方法。建立个数为m的最小堆,然后遍历n维护这个最小堆就可以了,算法的时间复杂度是n*log(m)。还是比较高效的算法的。


今天我又发现了一种解决方法,那就是STL里面的一种算法,STL里面的nth_element就是这样的一种算法。利用类似于快速排序的过程,找到前面的m个最大的数字。


不多说了,看代码吧。通过代码可以看出,和快排基本相似。


#include <iostream>
#include <cstdio>
using namespace std;

//在m个数中寻找最大的n个数
//将数组M[m]中的最大的n(n<m)个数放在数组前面
void search(int M[], int m, int n)
{
    if (n >= m) return;
    int t = M[0];
    int i = 0, j = m - 1;
    while (i < j) {
        while (i < j && M[j] < t) --j;
        if (i < j) M[i++] = M[j];

        while (i < j && M[i] >= t) ++i;
        if (i < j) M[j--] = M[i];
    }
    M[i] = t;
    if (i < n) {
        search(&M[i+1], m - i - 1, n - i - 1);
    } else if (i > n) {
        search(M, i, n);
    }
    return;
}

void test()
{
    int M[] = {8, 3, 9, 0, 4, 2, 5, 7, 1, 6};
    int m = 10, n = 6;

    printf("原始数据:");
    for(int i =  0; i < m; ++i)
        printf("%d ", M[i]);
    printf("\n");

    search(M, m, n);

    printf("结果数据:");
    for(int i = 0; i < n; ++i)
        printf("%d ", M[i]);
    printf("\n");
}

int main()
{
    test();
    return 0;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

【HDU4845】拯救大兵瑞恩(BFS+状态压缩)

题意:一个N*M的迷宫,要从左上角(1,1)走到右下角(N,M),每次可以往上下左右四个方向走一步。相邻两格之间可能有门或者墙,如有墙则不可通行,如有门则需要对应种类的钥匙才能打开。钥匙一共有P种,放...

寻找数组中的最大值和最小值

问题来源:《编程之美》2.10 寻找数组中的最大值和最小值 对于一个由N个整数组成的数组,需要比较多少次才能把最大和最小的数找出来呢? 1. 遍历两次数组,分别找出最大值和最小值。需要进行 2 *...

找出N个数据中的最大的K个数据---堆排序

从N个数据中找出最大的K个数据,而且这里有一个限制:内存里存不下所有的N个数据,但是可以存下K个数据。这就让我们打消了用排序的方法来解的念头。   在这里我们使用堆排序来完成。  650) this....

找出N个整数中最大的K个数

如题:给出N个整数(N可能很大,以致无法装入内存),找出前K个最大的整数 【解法一】 当学生们信笔写下 float array [10000000],他们往往没有想到这个数据结构 要如何在电脑上...

从n个无序的数中选出m个最大数

从n个无序的数中选出m个最大数

N个数里面找出最大的k个数

题目:给出N个无序的数,然后找出其中最大的k个数 解题思路:          首先测试数据有可能会有一亿个数,数据量特别的大,数据库不可能存储这么多的数据。如果直接sort排序,NlogN时间复...

从n个元素中找出第K小的数 利用快排的思想来实现

从n个无序的顺序表中找出第k小的数,采用快排思想: 先从n个元素中随便寻找一个数m作为分界点,m在列表中的位置为i 当 i = k时,m就是我们要寻找的第k小的数; 当 i > k时,我们就从1~i-...

N个数中找出最大的K个数

题目描述: 有很多个(N个)无序的数,我们姑且假定它们各不相等,怎么选出其中最大的若干个(k个)数呢? 1.N=100, K = 10的时候怎么处理? 2. N=1000, K = 100呢? ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)