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

1 vue (au cours des 30 derniers jours)
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 commentaires
Dang Manh Truong
Dang Manh Truong le 27 Jan 2019
Hey, when I try A = [1 1 1 1 1 1] it gives me an error :(
madhan ravi
madhan ravi le 27 Jan 2019
See the edited answer below.

Connectez-vous pour commenter.

Réponse acceptée

madhan ravi
madhan ravi le 27 Jan 2019
Modifié(e) : madhan ravi le 27 Jan 2019
idx=find(diff(A));
if A(1)==0
Result=0
elseif all(A)
Result=numel(A)
else
Result=idx(1)
end

Plus de réponses (0)

Catégories

En savoir plus sur Multidimensional Arrays dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by