Count the adjacent same elements in a vector

6 views (last 30 days)
Hello! Assume we have a vector of A=[1 1 1 2 2 3 3 3 3 3 1 1]. A has three 1, two 2, five 3 and two 1.
I need to create a vector, such as B=[3 2 5 2] and their corresponding value C=[1 2 3 1].
Maybe i should use a struct, not sure. Glad for some help :/
thx.

Accepted Answer

Matt J
Matt J on 1 Jul 2019
Edited: Matt J on 1 Jul 2019
L=cumsum([1, diff(A)~=0]);
B=splitapply(@sum,ones(size(A)),L)
C=splitapply(@min,A,L)
  2 Comments
Jos (10584)
Jos (10584) on 1 Jul 2019
Nice use of splitapply. Here is a simpler version of run-length encoding:
A=[1 1 1 2 2 3 3 3 3 3 1 1]
x = find([true diff(A)~=0])
B = diff([x numel(A)+1]) % run-lengths
C = A(x) % elements
ayça kepçe
ayça kepçe on 9 Jul 2019
Thank you so much! But if i had seen it one week ago, i would not lost a week in a six week internship. Sometimes a tiny code piece like this saves the entire project...

Sign in to comment.

More Answers (1)

Jos (10584)
Jos (10584) on 1 Jul 2019
This is call run-length encoding, for which you can find excellent function on the File exchange. For instance, [shameless self promotion ;-) ], this one: https://uk.mathworks.com/matlabcentral/fileexchange/56131-runindex
A = [1 1 1 2 2 3 3 3 3 3 1 1]
[~, RLE] = runindex(A)
B = RLE(:,3)
C = RLE(:,1)
  1 Comment
ayça kepçe
ayça kepçe on 9 Jul 2019
I tried to write a loop of my own, but didnt work so well :) your function will be in mind for incase!

Sign in to comment.

Categories

Find more on Operators and Elementary Operations in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!