Replace values in matrix by first non-zero value in previous row

5 visualizaciones (últimos 30 días)
Hi, how can i replace zero values in a matrix by the first occurring non-zero value in that matrix if you would loop backwards in each column? I.e. how can i carry forward a value as long as its next value in the same column is zero (without looping through each value in the matrix!)
Example: m_start = [3;0;0;4;0;5] replace_non_zero_values (m_start) = [3;3;3;4;4;5]
Hope you can help, thanks very much! Steven

Respuesta aceptada

Stephen23
Stephen23 el 5 de Mzo. de 2018
Editada: Stephen23 el 5 de Mzo. de 2018
>> M = [3;0;0;4;0;5];
>> idx = M~=0;
>> tmp = M(idx);
>> tmp(cumsum(idx))
ans =
3
3
3
4
4
5
Note this assumes that the first value is nonzero. You will need to think of how to deal with leading zeros!
  5 comentarios
Guillaume
Guillaume el 5 de Mzo. de 2018
Editada: Guillaume el 5 de Mzo. de 2018
idx = M(:) ~= 0
tmp = M(idx);
reshape(tmp(cumsum(idx)), size(M))
As with the original answer, this will go badly wrong if any column starts with a 0.
Arturo Camacho Lozano
Arturo Camacho Lozano el 21 de Jun. de 2019
Editada: Arturo Camacho Lozano el 21 de Jun. de 2019
Stephen's solution is very clever. Thanks!

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Logical en Help Center y File Exchange.

Productos

Community Treasure Hunt

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

Start Hunting!

Translated by