Vectorized method to find the number of consecutive 1s from the left of an array

3 ビュー (過去 30 日間)
Hi, I want to find the number of consecutive 1s from the left of an array (a binary array). For example, if I have A = [1 1 1 0 1 0 0 0 1 1] then the result would be 3 because there are 3 consecutive 1s from the left. Another example: A = [1 0 1 1 1 1 1] then the result would be 1. Or A = [0 1 1 1 0 0 1 0 1], the result would be 0.
I can write this in for loop, however I do not know how to vectorize this part. I really need it for my code so that it might run faster.
Please help me, thank you very much.
  4 件のコメント
Dang Manh Truong
Dang Manh Truong 2019 年 1 月 27 日
Hey, when I try A = [1 1 1 1 1 1] it gives me an error :(
madhan ravi
madhan ravi 2019 年 1 月 27 日
See the edited answer below.

サインインしてコメントする。

採用された回答

madhan ravi
madhan ravi 2019 年 1 月 27 日
編集済み: madhan ravi 2019 年 1 月 27 日
idx=find(diff(A));
if A(1)==0
Result=0
elseif all(A)
Result=numel(A)
else
Result=idx(1)
end

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeAxis Labels についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by