picking maximum difference across entries of row vectors, Part 3

The question is
for each row, take a difference between every possible pair of two elements in the row and returns the maximum difference
Now A can have missing values. For example, A =[ NaN NaN 3 9 4]. In this case the previous solution
vec = sort(A);
B = vec(end)-vec(1);
does not return a correct answer 6. Please advise.

2 commentaires

Suppose I replace NaN by -infty. Then the problem would be about taking the difference between max and min among nonzero elements for each row.
I can run a loop for each row calculates
max(D(i,:),[],'omitnan')-min(D(i,:),[],'omitnan');
but would hope simpler code.

Connectez-vous pour commenter.

 Réponse acceptée

A = [NaN NaN 3 9 4 ; 1 100 NaN 34 12];
maxdiffs = max(sort(A,2),[],2) - min(sort(A,2),[],2);

Plus de réponses (0)

Produits

Tags

Community Treasure Hunt

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

Start Hunting!

Translated by