Find first k largest elements?

15 views (last 30 days)
Rubel Ahmed
Rubel Ahmed on 13 Aug 2021
Commented: Matt J on 13 Aug 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.

Accepted Answer

Matt J
Matt J on 13 Aug 2021
Edited: Matt J on 13 Aug 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 Comments
Rubel Ahmed
Rubel Ahmed on 13 Aug 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 on 13 Aug 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.

Sign in to comment.

More Answers (0)

Products


Release

R2017a

Community Treasure Hunt

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

Start Hunting!