MATLAB: Self made sorting numbers function

I am trying to write my own sort function.. it gave me an error idk how to fix.
for j = 1:length(x)
for i = 1:length(x)-1
if x(i) < x(i+1)
minval = x(i);
val = x(i);
x(i) = [];
end
end
sortval(j) = val;
end
fprintf(sortval);

Best Answer

What is the point of assigning the same value to both minval and val ?
What is the point of assigning to minval when you never use minval again?
Note:
You are deleting elements from an array using a forward-indexing "for" loop. Suppose you have 4 elements and you delete the 2nd one in the loop:
i = 2, x = [A B C D], x(i) = []
now x = [A C D] because x(2) was deleted.
Now proceed to i = 3 in your for loop, and look at x(i). That is looking at D -- what happened to looking at C ?
When you delete something from vector, all the later elements "fall down" to fill the hole, getting renumbered along the way. If you increase the loop counter then you skip over the entry that fell down into the place you just looked.
You can deal with this in one of a few ways:
  1. avoid deleting elements at all (for example, copy elements into a different array instead of deleting them out of the existing array); or
  2. keep track of what is to be deleted but do not deleted it while you are looping; instead, at the end delete all of the ones you marked for deletion; or
  3. trick: run the loop backwards, from the end towards the beginning.