How to delete a zeros in matrix?

49 visualizaciones (últimos 30 días)
Matlab111
Matlab111 el 7 de Feb. de 2015
Comentada: Matlab111 el 8 de Feb. de 2015
I have a matrix like this
a=[ 0.7446 0.0364 186.1153 0 134.5022 114.8212 84.7745 130.8661
0 0 13.8840 0 16.1683 10.4461 69.8035 114.2774];
i want to delete zeros and their corresponding values. The solution should be like this...
b= [186.1153 134.5022 114.8212 84.7745 130.8661
13.8840 16.1683 10.4461 69.8035 114.2774];

Respuesta aceptada

Image Analyst
Image Analyst el 7 de Feb. de 2015
This will get rid of all columns that have a zero anywhere in them:
colsWithZeros = any(a==0)
b = a(:, ~colsWithZeros)
  2 comentarios
Jan
Jan el 7 de Feb. de 2015
If a gets a matrix with a single row unexpectedly, this will fail. Better specify the dimension to operate on explicitly:
colsWithZeros = any(a==0, 1)
Matlab's smart guess to operate on the first non-singelton dimension is a keen source of many bugs.
Matlab111
Matlab111 el 8 de Feb. de 2015
Image Analyst- Thank you

Iniciar sesión para comentar.

Más respuestas (2)

Jason Moore
Jason Moore el 7 de Feb. de 2015
Editada: Jason Moore el 7 de Feb. de 2015
I think this question was already asked before but this code should do it.
b = a(find(a~=0))
  2 comentarios
Image Analyst
Image Analyst el 7 de Feb. de 2015
Nope.
Matlab111
Matlab111 el 8 de Feb. de 2015
Thank you

Iniciar sesión para comentar.


ulgi onor
ulgi onor el 7 de Feb. de 2015
a(a==0)=[]
a =
Columns 1 through 9 0.7446 0.0364 186.1153 13.8840 134.5022 16.1683 114.8212 10.4461 84.7745 Columns 10 through 12 69.8035 130.8661 114.2774
  2 comentarios
David Young
David Young el 7 de Feb. de 2015
I think that what's wanted is a 2-row matrix with the relevant columns deleted.
This answer doesn't deliver that - it shares the same problem as Jason Moore's.
David Young
David Young el 7 de Feb. de 2015
Also note that your result has different elements to the matrix b in the question.

Iniciar sesión para comentar.

Categorías

Más información sobre Matrix Indexing 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