Find first k largest elements?

15 vues (au cours des 30 derniers jours)
Rubel Ahmed
Rubel Ahmed le 13 Août 2021
Commenté : Matt J le 13 Août 2021
Hi all
I have an array say A = [1 5 7 4 8 10 14]. I want to find most largest, second most largest and 3rd most largest elements from A.
I have figured out that it can be done using maxk function which is abailable for update version of Matlab but I am using R2017a where maxk function is not availablle.
Anyway, I want to see the output like Ans = [14 10 8]. Please help.Thanks in advance.

Réponse acceptée

Matt J
Matt J le 13 Août 2021
Modifié(e) : Matt J le 13 Août 2021
The efficient way would probably be to use a File Exchange MEX alternative to maxk() like this,
but you could also do,
A = [1 5 7 4 8 10 14];
B=sort(A,'descend');
B=B(1:3)
B = 1×3
14 10 8
  2 commentaires
Rubel Ahmed
Rubel Ahmed le 13 Août 2021
@Matt J thanks but I have figured out this is also useful
[~, idx] = sort(A);
ans = A(sort(idx(end-2:end)));
Matt J
Matt J le 13 Août 2021
I wouldn't recommend that.
A=rand(3e7,1);
tic;
B=maxk(A,3);
toc
Elapsed time is 0.039257 seconds.
tic;
B=sort(A,'descend');
B=B(1:3);
toc;
Elapsed time is 1.968519 seconds.
tic;
[~,idx]=sort(A);
B=A(idx(end:end-2));
toc
Elapsed time is 2.338227 seconds.

Connectez-vous pour commenter.

Plus de réponses (0)

Produits


Version

R2017a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by