Delete all values in a row after the first value
2 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Hi everyone
I have a matrix with 3000 rows and 4 columns. the values in the matrix are just one and zero. The sum of each row can just be one. In some rows the sum is 2. What I want now is to delete all 1 after the first 1. So in my matrix in each row I just want the first vaue 1 and all the following values in this matrix should be 0.
For example: row number 345: 0001000 1 0000 change to 0001000 0 0000
thank you for your help.
0 comentarios
Respuesta aceptada
KSSV
el 6 de Oct. de 2016
m = 10 ; n = 5 ;
A = randi([0 1],m,n) ;
B = zeros(size(A)) ;
for i = 1:m
idx = find(A(i,:)==1) ;
B(i,idx(1))= 1;
end
There might be more elegant solution.
5 comentarios
KSSV
el 6 de Oct. de 2016
m=5540 , n=4
FOMC_X_try = zeros(size(FOMC_X));
for i = 1:m
idx = find(FOMC_X(i,:)==1) ;
if ~isempty(idx)
FOMC_X_try(i,idx(1))= 1;
end
end
If there are no ones in a particular row, idx will be empty. So is the error.
Más respuestas (1)
Walter Roberson
el 6 de Oct. de 2016
Editada: Walter Roberson
el 6 de Oct. de 2016
B = cumsum(~cumprod(~A,2), 2) <= 1;
If I worked it out properly as I fall asleep...
0 comentarios
Ver también
Categorías
Más información sobre Resizing and Reshaping Matrices 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!