Delete all values in a row after the first value
2 次查看(过去 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.
0 个评论
采纳的回答
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;
end
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;
end
end
If there are no ones in a particular row, idx will be empty. So is the error.
更多回答(1 个)
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...
0 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Resizing and Reshaping Matrices 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!