finding only unique values
Show older comments
Suppose you have a column vector, the values are integers(in order) but some of them are repeated, e.g. it could be [1,1,1,1,2,3,3,4,5,5,5,5,5] I want to find the indices of unique values e.g. the index of 2 and 4 in the aforementioned example. the unique function in matlab returns on top of truly unique the first value of any nonunique value, so it would return the index of the first 1, the first 3 and first 5 but I don't want those
Accepted Answer
More Answers (2)
David Sanchez
on 22 Aug 2013
a=[1,1,1,1,2,3,3,4,5,5,5,5,5];
x = unique(a)
y = histc(a,x)==1;
lonely_values = find ( y == 1 )
or:
lonely_values = find ( (histc(a,unique(a))==1) == 1 )
lonely_values =
2 4
Azzi Abdelmalek
on 22 Aug 2013
[ii,jj]=sort(x);
out=sort(jj(strfind(logical([1 diff(ii) 1]),[true,true])))
Categories
Find more on Java Package Integration in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!