Count the adjacent same elements in a vector
6 次查看(过去 30 天)
显示 更早的评论
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 个评论
采纳的回答
Matt J
2019-7-1
编辑:Matt J
2019-7-1
L=cumsum([1, diff(A)~=0]);
B=splitapply(@sum,ones(size(A)),L)
C=splitapply(@min,A,L)
2 个评论
Jos (10584)
2019-7-1
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
更多回答(1 个)
Jos (10584)
2019-7-1
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)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Operators and Elementary Operations 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!