Find the longest streak of 1's from a vector

조회 수: 4 (최근 30일)
Vic
Vic 2014년 11월 27일
댓글: Image Analyst 2014년 11월 27일
Suppose I have a vector of 0's and 1's. How can I find, without for-loop(s), the longest streak of 1's in that vector?
eg. For the vector v=[0,1,0,0,1,1,0,0, 1,1,1,1,1 ,0,1,0,1], I want codes that return: longest streak=5, location=9 .
Any suggestion? Thanks in advance.

채택된 답변

Guillaume
Guillaume 2014년 11월 27일
I'm sure if you search cody you'll find a few of this type of problem. A combination of diff and find should do the trick. For example,
v=[0,1,0,0,1,1,0,0, 1,1,1,1,1 ,0,1,0,1];
vd = diff([0 v 0]); %the 0s ensure that there's always a pair of [+1 -1] in the diff
starts = find(vd == 1);
ends = find(vd == -1);
[longest_streak, idx] = max(ends-starts);
location = starts(idx);
  댓글 수: 2
Vic
Vic 2014년 11월 27일
thanks a lot.
Image Analyst
Image Analyst 2014년 11월 27일
Vic, you can also do it with regionprops() in the Image Processing Toolbox as an alternate method. Not sure it would be any fewer lines of code though.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Loops and Conditional Statements에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by