i've a matrix of 6x4 and i want to count the rows how many times it occur in a matrix

1 vue (au cours des 30 derniers jours)
let say the matrix is
A=[ 12 45 67 89
34 56 78 65
12 45 67 89
53 55 21 90
12 45 67 89
53 55 21 90 ]
i want the output to be as:
12 45 67 89 ----- 3 % because it occurs 3 times
34 56 78 65 ------1
53 55 21 90 ------2
plz help me

Réponse acceptée

Azzi Abdelmalek
Azzi Abdelmalek le 8 Mai 2013
A=[ 12 45 67 89
34 56 78 65
12 45 67 89
53 55 21 90
12 45 67 89
53 55 21 90 ]
[a,b,c]=unique(A,'rows','stable');
v=arrayfun(@(x) sum(c==x),1:size(a,1))';
out=[a v]
  2 commentaires
Emma Cairns
Emma Cairns le 9 Août 2017
I have an instance where I need to do this twice with two separate matrices and I keep getting the same output for both using this code, is there any way I can make it work? Thanks!
Jan
Jan le 9 Août 2017
Modifié(e) : Jan le 9 Août 2017
@Emma: Yes, there is a way. Of course there is. If you post the relevant part of your code (preferably as a new question and not by high-jacking this thread), we can even suggest a solution.
Andrei's method is slightly faster and (c)leaner.

Connectez-vous pour commenter.

Plus de réponses (1)

Andrei Bobrov
Andrei Bobrov le 8 Mai 2013
A=[ 12 45 67 89
34 56 78 65
12 45 67 89
53 55 21 90
12 45 67 89
53 55 21 90 ];
[a,c,c] = unique(A,'rows');
out = [a, histc(c,1:max(c))];

Catégories

En savoir plus sur Logical dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by