self made sorting numbers function
3 views (last 30 days)
Show older comments
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);
2 Comments
Rik
on 6 Mar 2017
If you want to do this, you should at the very least loop backwards through your vector. You are removing elements, so at some point x will no longer have the length that your for-loops expect.
Cameron Stark
on 16 Sep 2017
function b=downsort(b)
i=.5;
n = length(b);
while i<1
for x =1:n
if x ==n
i = 2;
break
end
if b(x) < b(x+1)
a = b(x);
b(x) = b(x+1);
b(x+1) = a;
break
end
end
Accepted Answer
Walter Roberson
on 6 Mar 2017
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:
- avoid deleting elements at all (for example, copy elements into a different array instead of deleting them out of the existing array); or
- 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
- trick: run the loop backwards, from the end towards the beginning.
0 Comments
More Answers (0)
See Also
Categories
Find more on Loops and Conditional Statements 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!