Count the adjacent same elements in a vector
6 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
ayça kepçe
am 1 Jul. 2019
Kommentiert: ayça kepçe
am 9 Jul. 2019
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.
0 Kommentare
Akzeptierte Antwort
Matt J
am 1 Jul. 2019
Bearbeitet: Matt J
am 1 Jul. 2019
L=cumsum([1, diff(A)~=0]);
B=splitapply(@sum,ones(size(A)),L)
C=splitapply(@min,A,L)
2 Kommentare
Jos (10584)
am 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
Weitere Antworten (1)
Jos (10584)
am 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)
Siehe auch
Kategorien
Mehr zu Operators and Elementary Operations finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!