相关疑难解决方法(0)

查找数组中的前n个最大元素

我有一个包含唯一元素的数组.我需要以尽可能最小的复杂性找出数组中的前n个最大元素.到目前为止,我能想到的解决方案具有O(n ^ 2)的复杂性.

    int A[]={1,2,3,8,7,5,3,4,6};
    int max=0;
    int i,j;
    int B[4]={0,0,0,0,};//where n=4;
     for(i=0;i<A.length();i++)
       {
         if(A[i]>max)
          max=A[i];
       }
     B[0]=max;
     for(i=1;i<n;i++){
       max=0;
       for(j=0;j<A.length();j++){
         if(A[j]>max&&A[j]<B[i-1])
            max=A[j];
       }
        B[i]=max;
     }
Run Code Online (Sandbox Code Playgroud)

如果有人能提出一个更复杂的解决方案,我将非常感激.而且我不打算改变原来的阵列!

c arrays algorithm complexity-theory

14
推荐指数
2
解决办法
3万
查看次数

标签 统计

algorithm ×1

arrays ×1

c ×1

complexity-theory ×1