picking maximum difference across entries of row vectors, Part 3

1 vue (au cours des 30 derniers jours)
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
alpedhuez
alpedhuez le 6 Juin 2018
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.
alpedhuez
alpedhuez le 7 Juin 2018
Modifié(e) : alpedhuez le 7 Juin 2018
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

Kaushik Lakshminarasimhan
Kaushik Lakshminarasimhan le 7 Juin 2018
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)

Catégories

En savoir plus sur Logical dans Help Center et File Exchange

Tags

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by