Delete all values in a row after the first value

3 次查看(过去 30 天)
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.


KSSV 2016-10-6
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;
There might be more elegant solution.
  5 个评论
KSSV 2016-10-6
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;
If there are no ones in a particular row, idx will be empty. So is the error.
FC93 2016-10-6
I replaced the old code with this one. Now it works. thank you very much for your help and your time.


更多回答(1 个)

Walter Roberson
Walter Roberson 2016-10-6
编辑:Walter Roberson 2016-10-6
B = cumsum(~cumprod(~A,2), 2) <= 1;
If I worked it out properly as I fall asleep...


Help CenterFile Exchange 中查找有关 Numeric Types 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by