Откорректировать программу на Turbo Pascal
Код:
Uses Crt;
Const N = 50;
Type T_Mas = Array [1..N] of Integer;
Var Mas : T_Mas;
Kol : Integer;
Procedure Count (Var Kol:Integer);
{Процедура определения размерности массива}
Var IOR : Word;
Begin
Write('Введите размерность массива: ');
Repeat
{$I-} ReadLn(Kol); {$I+}
IOR := IOResult;
If odd(IOR) or (Kol>N) Then
WriteLn('Ошибка. Повторите ввод.')
Until (Kol<=N) and (IOR=0)
End;
Procedure Filling (Kol:Integer; Var A: T_Mas);
{Процедура заполнения массива}
Var I : Integer;
Begin
Randomize;
For I := 1 To Kol Do A[I] := Random(N)
End;
Procedure Print (Kol:Integer; A: T_Mas);
{Процедура вывода массива}
Var I : Integer;
Begin
For I:=1 to Kol do Write (A[I], ' ')
End;
Procedure Vibor (var X:T_Mas);
var k,i,j,x,buf:byte;
k:=X div 2;
{сортировка выбором по возрастанию первой половины}
for i:=1 to k-1 do
begin
x:=i;
for j:=i+1 to k do
if a[j]<a[x] then x:=j;
buf:=a[i];
a[i]:=a[x];
a[x]:=buf;
end;
{сортировка выбором по убыванию второй половины}
for i:=k+1 to n-1 do
begin
x:=i;
for j:=i+1 to n do
if a[j]>a[x] then x:=j;
buf:=a[i];
a[i]:=a[x];
a[x]:=buf;
end;
Begin
ClrScr;
Count(Kol);
Filling(Kol, Mas);
WriteLn('Исходный массив'); Print (Kol, Mas);
Vibor (Mas);
WriteLn;
WriteLn('Отсортированный массив'); Print (Kol, Mas);
Repeat until KeyPressed
End.
Const N = 50;
Type T_Mas = Array [1..N] of Integer;
Var Mas : T_Mas;
Kol : Integer;
Procedure Count (Var Kol:Integer);
{Процедура определения размерности массива}
Var IOR : Word;
Begin
Write('Введите размерность массива: ');
Repeat
{$I-} ReadLn(Kol); {$I+}
IOR := IOResult;
If odd(IOR) or (Kol>N) Then
WriteLn('Ошибка. Повторите ввод.')
Until (Kol<=N) and (IOR=0)
End;
Procedure Filling (Kol:Integer; Var A: T_Mas);
{Процедура заполнения массива}
Var I : Integer;
Begin
Randomize;
For I := 1 To Kol Do A[I] := Random(N)
End;
Procedure Print (Kol:Integer; A: T_Mas);
{Процедура вывода массива}
Var I : Integer;
Begin
For I:=1 to Kol do Write (A[I], ' ')
End;
Procedure Vibor (var X:T_Mas);
var k,i,j,x,buf:byte;
k:=X div 2;
{сортировка выбором по возрастанию первой половины}
for i:=1 to k-1 do
begin
x:=i;
for j:=i+1 to k do
if a[j]<a[x] then x:=j;
buf:=a[i];
a[i]:=a[x];
a[x]:=buf;
end;
{сортировка выбором по убыванию второй половины}
for i:=k+1 to n-1 do
begin
x:=i;
for j:=i+1 to n do
if a[j]>a[x] then x:=j;
buf:=a[i];
a[i]:=a[x];
a[x]:=buf;
end;
Begin
ClrScr;
Count(Kol);
Filling(Kol, Mas);
WriteLn('Исходный массив'); Print (Kol, Mas);
Vibor (Mas);
WriteLn;
WriteLn('Отсортированный массив'); Print (Kol, Mas);
Repeat until KeyPressed
End.