У меня есть массив, содержащий уникальные элементы. Мне нужно узнать первые 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;
}
Пожалуйста, если кто-нибудь может придумать лучшее решение, которое потребует меньшей сложности, я буду очень благодарен. И я не собираюсь менять исходный массив!