How do I get an index like with ismember, but with values representing the number of occurances?

3 visualizaciones (últimos 30 días)
I have some vectors, let's call them A and B, and I want to find all elements of A contained within B. So far I've gotten an logical index of all the unique elements, but I need to go one step further and count up repetitions as well. So for instance:
A = ['monday', 'tuesday', 'thursday', 'monday']
B = ['monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday', 'sunday']
Index = [2 1 0 1 0 0 0]

Respuesta aceptada

Stephen23
Stephen23 el 1 de Mzo. de 2017
Editada: Stephen23 el 1 de Mzo. de 2017
>> A = {'monday', 'tuesday', 'thursday', 'monday'};
>> B = {'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday', 'sunday'};
>> idx = cellfun(@(s)nnz(strcmp(A,s)),B)
idx =
2 1 0 1 0 0 0

Más respuestas (1)

Steven Lord
Steven Lord el 1 de Mzo. de 2017
A = {'monday', 'tuesday', 'thursday', 'monday'};
B = {'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday', 'sunday'};
Ac = categorical(A, B);
Bc = categorical(B);
histcounts(Ac, Bc)
If your data is numeric you can skip the categorical steps, though you will need to add an extra element to the end of the second input. For categorical data, histcounts uses each category as a bin; for numeric data, it uses the second input as the edges of the bin. By default the leftmost edges are included in the bins. The extra element will be the rightmost edge of the last bin and will catch elements equal to the next to last element of the edges vector.
A = [1 2 4 1];
B = [1:7 Inf];
histcounts(A, B)

Categorías

Más información sobre Categorical Arrays en Help Center y File Exchange.

Productos

Community Treasure Hunt

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

Start Hunting!

Translated by