How do I sort an array in descending order without using the sort function?

5 views (last 30 days)
A = [2 1 4 3 6 5 8 7 10 9 12 11 14 13 16 15 18 17 20 19]

Accepted Answer

Thorsten
Thorsten on 5 Nov 2015
You can use bubble sort:
swapped = 1;
while swapped
swapped = 0;
for i=1:numel(A)-1
if A(i+1) > A(i)
temp = A(i); A(i) = A(i+1); A(i+1) = temp; swapped = 1;
end
end
end

More Answers (2)

Walter Roberson
Walter Roberson on 5 Nov 2015
flipud(unique(A(:)))

Stephen23
Stephen23 on 5 Nov 2015
Edited: Stephen23 on 5 Nov 2015
Here are a few ways to sort an array of unique values without using sort:
sortrows(A(:),-1)
A(end:-1:1) = unique(A);
fliplr(union(A,A(1)))
fliplr(setdiff(A,NaN))

Categories

Find more on Shifting and Sorting Matrices in Help Center and File Exchange

Tags

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!