В заданной прямоугольной матрице найти: максимальный элемент и левее столбца, который содержит этот элемент, - Free Pascal
Формулировка задачи:
В заданной прямоугольной матрице найти: максимальный элемент и левее столбца, который содержит этот элемент, вставить столбец,
состоящий из чисел, равных найденному максимальному элементу;
Решение задачи: «В заданной прямоугольной матрице найти: максимальный элемент и левее столбца, который содержит этот элемент,»
textual
Листинг программы
const nmax=10;
var a:array[1..nmax,1..nmax+1] of integer;
n,m,i,j,jmx,p:byte;
mx:integer;
begin
randomize;
repeat
write('Количество строк до ',nmax,' n=');
readln(n);
until n in [1..nmax];
repeat
write('Количество столбцов до ',nmax,' m=');
readln(m);
until m in [1..nmax];
writeln('Исходная матрица:');
for i:=1 to n do
begin
for j:=1 to m do
begin
a[i,j]:=10+random(89);
write(a[i,j]:4);
end;
writeln;
end;
writeln;
mx:=a[1,1];
jmx:=1;
for i:=1 to n do
for j:=1 to m do
if a[i,j]>mx then
begin
mx:=a[i,j];
jmx:=j;
end;
writeln('Первый максимальный элемент=',mx,' в столбце ',jmx);
m:=m+1;
for j:=m downto jmx+1 do
for i:=1 to n do
a[i,j]:=a[i,j-1];
for i:=1 to n do
a[i,jmx]:=mx;
writeln('Вставка столбца из максимальных перед столбцом с максимальным:');
for i:=1 to n do
begin
for j:=1 to m do
write(a[i,j]:4);
writeln;
end;
readln
end.
Объяснение кода листинга программы
- Объявлены переменные: n, m, i, j, jmx, p (byte), mx (integer), a (array[1..nmax,1..nmax+1] of integer).
- Выполняется инициализация генератора случайных чисел.
- Пользователю предлагается ввести количество строк и столбцов для матрицы (повторяется, пока не введется корректное значение).
- Выводится исходная матрица (числа от 10 до 99).
- Находится максимальное значение в матрице (mx) и его позиция (jmx).
- Второй максимальный элемент перед столбцом с максимальным удаляется, начиная с столбца m+1, вставляется в конец столбца с максимальным.
- Выводится измененная матрица.
- Программа ожидает ввода, чтобы закрыть соединение с консолью.