Сформировать вектор В из тех элементов исходной матрицы,которые меньше по модулю, чем найденное значение среднего арифметического.Затем упорядочить элементы вектора В по возрастанию.Напечатать В до и после сортировки — Pascal(Паскаль)

uses crt;
const max=20;
var a:array[1..max,1..max] of integer;
    b:array[1..max*max] of integer;
    m,n,i,j,k:byte;
    sr:real;
    x:integer;
begin
clrscr;
repeat
write('Количество строк m=');
readln(m);
until m in [1..max];
repeat
write('Количество столбцов n=');
readln(n);
until n in [1..max];
writeln('Исходная матрица:');
for i:=1 to m do
 begin
   for j:=1 to n do
    begin
     a[i,j]:=random(20)-4;
     write(a[i,j]:5);
    end;
   writeln;
 end;
{находим среднее}
sr:=0;
for i:=1 to m do
for j:=1 to n do
sr:=sr+a[i,j];
sr:=sr/(m*n);
writeln('Среднее=',sr:0:1);
writeln;
{делаем вектор}
k:=0;
for i:=1 to m do
for j:=1 to n do
if abs(a[i,j])<abs(sr) then
 begin
  k:=k+1;
  b[k]:=a[i,j];
 end;
writeln('Вектор В:');
for i:=1 to k do
write(b[i],' ');
writeln;
writeln;
{сортировка по возрастанию простым обменом}
for i:=1 to k-1 do
for j:=i+1 to k do
if b[i]>b[j] then
 begin
  x:=b[i];
  b[i]:=b[j];
  b[j]:=x;
 end;
writeln('Массив В по возрастанию:');
for i:=1 to k do
write(b[i],' ');
readln
end.

Leave a Comment

− 1 = 1