Sort using flow control

1 Ansicht (letzte 30 Tage)
Aggie
Aggie am 5 Sep. 2014
Bearbeitet: Star Strider am 5 Sep. 2014
I am new to MATLAB...first assignment and I have been tasked to build a MATLAB function that is to sort an array of numbers using flow control (smallest to largest). Then I am supposed to return the argument in a new similar array. Can anybody help me at least get started with this task?

Antworten (2)

Sean de Wolski
Sean de Wolski am 5 Sep. 2014
function sorted = mysort(x)
sorted = sort(x);
end
  1 Kommentar
Aggie
Aggie am 5 Sep. 2014
I'm not allowed to use any built in MATLAB functions for sorting

Melden Sie sich an, um zu kommentieren.


Star Strider
Star Strider am 5 Sep. 2014
This is how I would do the sorting:
x = randi(20,50,1);
x = x(:);
srtd = [];
for k1 = 1:length(x)
[sx,ix] = min(x);
srtd = [srtd; sx];
x(ix) = [];
end
The ‘srtd’ array would be the returned output.
  2 Kommentare
Aggie
Aggie am 5 Sep. 2014
Does this output the answer in the same "shape" as the original array?
Thanks
Star Strider
Star Strider am 5 Sep. 2014
Bearbeitet: Star Strider am 5 Sep. 2014
My pleasure!
You said ‘array’ and I read ‘vector’. This corrects my oversight.
This will work for an (NxM) matrix:
x = randi(50,20,2); % Argument
[ar,ac] = size(x);
for k1 = 1:ac
svct = [];
xa = x(:,k1);
for k2 = 1:ar
[sx,ix] = min(xa);
svct = [svct; sx];
xa(ix) = [];
end
srtd(:,k1) = svct;
end
Run it and see if it works for you. The returned array ‘srtd’ is the same size as ‘x’, the input argument matrix (or vector). If you want to sort in descending order, replace min with max.

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Shifting and Sorting Matrices finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by