self made sorting numbers function
3 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
zhi zhu
le 6 Mar 2017
Commenté : Cameron Stark
le 16 Sep 2017
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 commentaires
Rik
le 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
le 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
Réponse acceptée
Walter Roberson
le 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 commentaires
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Loops and Conditional Statements dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!