Get rid of an unwanted zero element in an IF loop

1 view (last 30 days)
I'm trying to create a function that returns only the elements in a vector which repeats exactly three times using the following code:
function y = three_times(x)
a = sort(x)
b = unique(a)
for i = 1:numel(b)
c = find(b(i) == a)
d = length(c)
if d == 3
e(i) = b(i)
end
end
y = e
If I apply this function to a vector like
x = [1 2 5 2 2 7 8 3 3 1 3 8 8 8]
I get y = [0 2 3] instead of y = [2 3]. Any hints on how can I repair this?

Accepted Answer

Azzi Abdelmalek
Azzi Abdelmalek on 5 May 2014
x = [1 2 5 2 2 7 8 3 3 1 3 8 8 8]
[freq,a]=hist(x,unique(x))
out=a(freq==3)
  2 Comments
Agent Cooper
Agent Cooper on 5 May 2014
Azzi,
Thank you very much for your very elegant and compact code. It works just fine.
However, I would be grateful if you (or anyone else) could also give me a hint regarding the problem in my code.
Azzi Abdelmalek
Azzi Abdelmalek on 5 May 2014
Ok, first
a = sort(x)
b = unique(a)
is equivalent to
b=unique(x)
because, by default the function unique will sort your result
Use numel(b) instead of length(b). In your case they give the same result.
The hint for your problem is the counter i you are using. Because d is not always equal to 3, when for example i=1 is skipped, you will get e(1)=0; to avoid this problem, use another counter, for example
k=0
If d==3
k=k+1
%do
end

Sign in to comment.

More Answers (0)

Categories

Find more on MATLAB 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!