Сценарий находится на стр. 438 книги, 2-е издание. Вот оно:
function a = quicksort(a, from, to)
clear, clc, close all
if (from < to)
[a p] = partition(a, from, to);
a = quicksort(a, from, p);
a = quicksort(a, p+1, to);
end
function [a lower] = partition(from,to)
pivot = a(from); i = from - 1; j = to + 1;
while (i<j)
i = i + 1;
while lt(a(i),pivot)
i = i + 1;
end
j = j - 1;
while gt(a(j), pivot)
j = j - 1;
end
if (i<j)
temp = a(i);
a(i) = a(j);
a(j) = temp;
end
end
lower = j;
a
Мне не удается выполнить скрипт, чтобы увидеть результат, и я продолжаю получать следующую ошибку (даже если я изменяю входные данные):
??? Error using ==> quicksort>partition
Too many input arguments.
Error in ==> quicksort at 9
[a p] = partition(a, from, to);
Может кто-нибудь, пожалуйста, помогите мне? Мне очень интересны эти методы сортировки Matlab. Спасибо.