How do I sort the max values from a matrix ?

1 Ansicht (letzte 30 Tage)
Pierre Lonfat
Pierre Lonfat am 23 Mai 2017
Bearbeitet: KSSV am 23 Mai 2017
Hello everyone !
In the following 577X2 matrix I have tickers of stocks in the first column and the number of occurence in the second one.
How would I keep the 80 first stocks (tickers) that occurred the most ?
Many thanks in advance !
Pierre

Akzeptierte Antwort

Guillaume
Guillaume am 23 Mai 2017
Bearbeitet: Guillaume am 23 Mai 2017
[~, order] = sort(Occurences.Momentum(:, 2), 'descend');
top80 = Occurences.Momentum(order(1:80), :)
Or:
sortedData = sortrows(Occurences.Momentum, 2, 'descend');
top80 = sortedData(1:80, :)

Weitere Antworten (1)

KSSV
KSSV am 23 Mai 2017
Bearbeitet: KSSV am 23 Mai 2017
Let data be you 577X2 data.
[val,idx] = sort(data(:,2),'descend') ; % sort the second column in descending order
iwant = data(idx(1:80),:) ; % pick first 80 most occurring stocks

Kategorien

Mehr zu Shifting and Sorting Matrices finden Sie in Help Center und File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!

Translated by