Программа


PROGRAM Matrix;
CONST MaxQuant=20; { Максимальное количество строк и столбцов матрицы }
TYPE Power=1..MaxQuant; { Размерность массивов }
     Element=real; { Тип элементов массивов }
     SqrMatrixType=record { Тип - квадратная матрица }
                     P:Power; { Размерность матрицы }
                     M:array[Power,Power] of Element { Массив элементов (матрица)}
                   end;

PROCEDURE ReadMatrix(var F:text; var A:SqrMatrixType); { Процедура ввода вектора }
  Var i:0..MaxQuant;               { Счетчик строк }
      j:0..MaxQuant;               { Счетчик столбцов }
  Begin
    Reset(F); { Открытие файла для чтения }
    i:=0; { Сброс счетчика строк }
    while not EOF(F) do { Цикл чтения файла }
      begin
        i:=i+1; { Определение номера строки }
        j:=0; { Сброс счетчика столбцов }
        while not EOLn(F) do
        begin
          j:=j+1; { Определение номера элемента в строке }
          Read(F,A.M[i,j])  { Чтение элемента матрицы }
        end;
        ReadLn(F)  { Чтение конца строки файла }
      end;
    Close(F); { Закрытие файла }
    A.P:=j { Определение размерности матрицы }
  End;
PROCEDURE WriteMatrix(var F:text; Head:string; var A:SqrMatrixType); { Процедура вывода матрицы }
  Var i:Power;               { Счетчик строк }
      j:Power;               { Счетчик столбцов }
  Begin
    Rewrite(F);                       { Открытие файла для записи }
    if Head<>'' then WriteLn(F,Head); { Вывод заголовка }
    for i:=1 to A.P do                { Цикл вывода строк }
    begin
      for j:=1 to A.P do                { Цикл вывода стрки }
        Write(F,A.M[i,j]:5:2,'   ');      { Вывод элемента }
      WriteLn(F)                        { Вывод конца строки }
    end;
    Close(F)                          { Закрытие файла }
  End;
PROCEDURE Mirror(var A:SqrMatrixType); { Процедура перестановки диагоналей прилегающих к главной }
  Var i:Power;    { Счетчик строк }
      j:Power;    { Счетчик столбцов }
      Buf:Element;{ Вспомогательная переменная для перестановки элементов матрицы }
  Begin
    for i:=1 to A.P do          { Цикл перестановки строк }
      for j:=i+1 to A.P do          { Цикл перестановки стрки }
      begin
        { Перестановка элементов: }
        Buf:=A.M[j,i];
        A.M[j,i]:=A.M[i,j];         
        A.M[i,j]:=Buf
      end
  End;
VAR A:SqrMatrixType; { Матрица }
    F:text; { Указатель файловой переменной }
BEGIN
  WriteLn;                             { Пропуск строки }
  Assign(F,'init.dat');                { Связывание указателя с именем файла }
  ReadMatrix(F,A);                     { Ввод матрицы }
  Assign(F,'con');    { Связывание указателя с именем файла (консоль) }
  WriteMatrix(F,'ИСХОДНАЯ МАТРИЦА',A); { Вывод матрицы }
  WriteLn;                             { Пропуск строки }
  Mirror(A);                           { Обработка матрицы }
  WriteMatrix(F,'"ПЕРЕВЕРНУТАЯ" МАТРИЦА',A); { Вывод матрицы }
  WriteLn                             { Пропуск строки }
END.

Бесплатные примеры программ
Примеры написанных программ
Помощь студентам по программированию