Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Deleting non-unique rows from an array

I have an array a as follows:

a = [ 1 2; 3 4; 1 2 ];

I want to delete all rows appearing more than once in a and get c:

c = [ 3 4 ];

Please note that this is not the same operation as keeping unique rows, since I don't want rows that had duplicates to appear at all. How can I accomplish this?

like image 912
fili Avatar asked Apr 29 '26 13:04

fili


1 Answers

The third output of unique gives you the index of the unique row in the original array. You can use this with accumarray to count the number of occurrences, which can be used to select rows that occur only once.

For example:

A = [1 2; 3 4; 1 2];

[uniquerow, ~, rowidx] = unique(A, 'rows'); 
noccurrences = accumarray(rowidx, 1);

C = uniquerow(noccurrences==1, :);

Which returns:

>> C

C =

     3     4
like image 149
sco1 Avatar answered May 02 '26 06:05

sco1



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!