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!