Версия для печати темы

Нажмите сюда для просмотра этой темы в обычном формате

Форум «Всё о Паскале» _ Задачи _ Счётчик

Автор: Anastacia Adesso 24.05.2006 21:45

Приветик, ребята!!
У меня тут появилась небольшая проблемма..
Препод хочет, чтоб в этой программе на экран выводилось количество сравнений в обоих методах (пузырёк и Хоара). Я не врубаюсь,куда это надо поставить? Помогите, пожалуйста..


Прикрепленные файлы
Прикрепленный файл  BURBULIS.PAS ( 1.38 килобайт ) Кол-во скачиваний: 308

Автор: volvo 24.05.2006 22:31

(будем считать, что Count - глобальная переменная, в которой будет число сравнений, и Count ПЕРЕД вызовом сортировки присваивается 0):

var
count: integer;

function isGreater(a, b: integer): boolean;
begin
inc(count);
isGreater := (a > b);
end;

{metod puzyrjka}
procedure puzirek(var x:masiv; a:integer);
var
i, j: integer;

procedure oborot(var a,b:integer);
var c: integer;
begin
c:=a; a:=b; b:=c;
end;

begin
for i:=a-1 downto 1 do
for j:=1 to i do
if isGreater(x[j], x[j+1]) then oborot(x[j], x[j+1]);
end; {konec}

{metod Hoara}
procedure hoars(var x:masiv; l, u:integer);
var
i, j, T: integer;
begin
while u > l do begin
i:=l; j:=u; t:=x[l];
while i<j do begin
while isGreater(x[j], t) do j:=j-1;
x[i]:=x[j];
while(i<j) and (not isGreater(x[i], t)) do i:=i+1; x[j]:=x[i];
end;

x[i]:=t;
hoars(x,l,i-1);
inc(l);
end;
end;{konec}

Идея понятна? smile.gif Не забудь обнулять Count перед вызовом КАЖДОЙ сортировки...

Хотя в реализации сортировки Хоара есть сомнения... Загляни в "FAQ: Методы сортировки", проверь, возможно там более быстрая реализация...

Автор: Anastacia Adesso 25.05.2006 14:12

Да. В общем понятен сам процесс..
Спасибо!!!