How can I get a row vector where a specific element found is located within a matrix?

I am trying to write a program that gives a row vector from a matrix that has the lowest element from a specific column. For example, say if I have the following,
A =
2009 8 2 4
2010 3 4 5
2011 6 9 1
2012 1 3 7
If I want to find the smallest value in column 3, which is 2, how do I get MATLAB to give the row where it is found, so that the result is
ans =
2009 8 2 4
I have been struggling with this for the past 2 days and I feel like because I've stared at this for so long I can't spot the problem. Can I get some help please?

 Risposta accettata

A =[
2009 8 2 4
2010 3 4 5
2011 6 9 1
2012 1 3 7];
[ii,ii] = min(A(:,3));
out = A(ii,:);
or
out = A(abs(A(:,3) - min(A(:,3))) < eps(100),:);

Più risposte (1)

Thank you! I do have a question, however. Why are you using ii twice? What does this do that allows to get the row vector where a specific element found is located within a matrix? I ask this so that I know next time.

3 Commenti

That's just an old trick for ignoring the first output from min -- you don't actually need the minimum value, just its location. But MATLAB assigns multiple function outputs by order; for min the first output is the minimum value, the second is its location. If you're using any recent version of MATLAB, a neater(?) solution is
[~,ii] = min(A(:,3));
out = A(ii,:);
BTW, is it possible that you would have multiple locations with the same minimum value? If so, how do you want to deal with it? Andrei's answer will give the first row that matches. If you need all rows that match:
idx = A(:,3)==min(A(:,3));
out = A(idx,:);
(Of course, both are equivalent if there's only one minimum.)
Hi Matt! Second part in my answer?(after 'or')
Oh, yes, you're right -- I was a bit confused by the eps and didn't look too closely.

Accedi per commentare.

Community Treasure Hunt

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

Start Hunting!

Translated by