PROGRAM PRG7_9;
CONST N = 100; VAR А, В: ARRAY[1..N, 1..N] OF INTEGER; К, М, I, J: INTEGER; BEGIN WRITE('BBEДИTE РАЗМЕР МАТРИЦЫ М ='); READLN (M); WRITELN('ИСХОДНАЯ МАТРИЦА'); K:= 1; FOR I:= 1 ТО М DO FOR J:= 1 TO M DO BEGIN A[l, J]:= K; K:=K+1; IF J<M THEN WRITE(A[I, J]: 4) ELSE WRITELN(A[I, J]: 4) END; WRITELN('MATPИЦA ПОСЛЕ ПРЕОБРАЗОВАНИЯ'); FOR I:= 1 TO M DO FOR J:= 1 TO M DO BEGIN B[l, J]:= A[M+1- I, J]; IF J<M THEN WRITE(B[I, J]: 4) ELSE WRITELN(B[I, J]: 4) END; END. Для решения задачи: - формируем тело программы и описываем переменные; - вводим размеры массива А и присваиваем значения его элементам; - присваиваем значения элементам матрицы В и выводим их на экран. Переменные: А, В - двумерные массивы; М - количество строк и столбцов массива; I, J - переменные цикла; К - вспомогательная переменная.
ВВЕДИТЕ РАЗМЕР МАТРИЦЫ М = 4 ИСХОДНАЯ МАТРИЦА 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 МАТРИЦА ПОСЛЕ ПРЕОБРАЗОВАНИЯ 13 14 15 16 9 10 11 12 5 6 7 8 1 2 3 4 Рис. 7.7. Результат работы PRG7_9 Задача 7.10 Дана квадратная матрица N х N, состоящая из натуральных чисел. Зеркально отразить ее элементы относительно вертикальной оси симметрии. Вывести результат на экран. Рассмотрим вначале матрицу 3 х 3 и посмотрим, что происходит с элементами при зеркальном отражении.
Если считать, что после преобразования у нас появилась новая матрица В, то соответствие между элементами устанавливается следующим образом: В 11 «А 13 В 12 «А 23 В 21 «А 23 В 22 «А 22 и т. д., т. е. В [I, J] «A [L, М]. Внимательно изучив соответствие, можно утверждать, что для элементов матрицы N х N справедлива следующая система уравнений: Отсюда правило преобразования элементов выглядит следующим образом: В [I, J] = A [I, N+1-J]. Программа, решающая данную задачу, выглядит так:
|