finding the 10 lowest values

19 visualizaciones (últimos 30 días)
Adam
Adam el 13 de Oct. de 2011
Comentada: Adam el 23 de Feb. de 2017
I have a matrix with a lot of data, and i want to find the 10 lowest values of a specific collum.
Does anybody know how to do that?
i was thinking about using the function min() but it does not allow me to select a specific collum, or finding more than the one value which is the lowest.

Respuesta aceptada

Artik Crazy
Artik Crazy el 13 de Oct. de 2011
  • Let's say you have a matrix of 10x10:
x=rand (10,10);
  • Sort it by the columns in ascending order:
y=sort (x,1, 'ascend')
*Now take the 5 first rows - these are the lowest values in every column:
z=y(1:5, :)

Más respuestas (2)

the cyclist
the cyclist el 13 de Oct. de 2011
First 10 values of "sorted_x" is what you want.
A = rand(100,10);
columnToSort = 7;
[sorted_x, index] = sort(A(:,columnToSort),'ascend');

Marc
Marc el 23 de Feb. de 2017
But if I want the indexes of these 10 values? Should I sort to find the values and then "find" these values in the matrix?
Is there a more elegant way?
  1 comentario
Adam
Adam el 23 de Feb. de 2017
the cyclist gave an answer that also returns indices. You can just feed these directly into your array.

Iniciar sesión para comentar.

Categorías

Más información sobre Shifting and Sorting Matrices en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by