<em>// PascalABC.NET 3.3, сборка 1590 от 03.12.2017</em>
<em>// Внимание! Если программа не работает, обновите версию!</em>
function ReadMatrix(c:char; m,n:integer):array[,] of real;
begin
Writeln('Вводите элементы матрицы ',c,' построчно');
Result:=ReadMatrReal(m,n);
end;
function MatProd(a,b:array[,] of real):array[,] of real;
begin
var (m,n):=(a.RowCount,a.ColCount);
Result:=new real[m,n];
for var i:=0 to m-1 do
for var j:=0 to n-1 do
Result[i,j]:=a[i,j]*b[i,j]
end;
begin
var (m,n):=ReadInteger2('Количество строк и столбцов в матрицах:');
var A:=ReadMatrix('A',m,n);
var B:=ReadMatrix('B',m,n);
var C:=ReadMatrix('C',m,n);
var AB:=MatProd(A,B);
Writeln('*** A*B ***');
AB.Print(8,4); Writeln(8*n*'-');
var AC:=MatProd(A,C);
Writeln('*** A*C ***');
AC.Print(8,4); Writeln(8*n*'-');
var BC:=MatProd(B,C);
Writeln('*** B*C ***');
BC.Print(8,4)
end.
<u>Пример</u>
Количество строк и столбцов в матрицах: 3 4
Вводите элементы матрицы A построчно
2.1 3.2 -1.7 4
-2 0 6.1 0.3
0.2 1.7 -2 0.5
Вводите элементы матрицы B построчно
1 2 3 4
5 6 7 8
-1 -2 -3 -4
Вводите элементы матрицы C построчно
8.3 2.12 5.7 0
3.9 7.7 4 1
-1 -2 5.2 -0.9
*** A*B ***
2.1000 6.4000 -5.1000 16.0000
-10.0000 0.0000 42.7000 2.4000
-0.2000 -3.4000 6.0000 -2.0000
--------------------------------
*** A*C ***
17.4300 6.7840 -9.6900 0.0000
-7.8000 0.0000 24.4000 0.3000
-0.2000 -3.4000-10.4000 -0.4500
--------------------------------
*** B*C ***
8.3000 4.2400 17.1000 0.0000
19.5000 46.2000 28.0000 8.0000
1.0000 4.0000-15.6000 3.6000
Так как неуказан язык программирования пишу алгоритм
1)Открываем поток для чтения файла f , нам еще потребуется переменная назовем ее count (Тип дробных чисел в каждом языке по разному) и переменную допустим value (тоже дробное) Далее проход по файлу любым циклом до конца файла и условие если value = дробь то count = count +1 И в конце выводим count в файл g
2)Открываем поток для чтения файла f , и две переменные max и min и массив кол-во элементов которого равно кол-ву чисел в файле (Считаем любой функцией ) далее сортируем массив по возрастанию и получиться max = последний элемент массива ;
min = первый элемент массива . Далее выводим min и max в файл g
3)Аналогично 4 только вместо записи их в массив просто задаете переменную которая будет увеличиваться если число четное .
4)Открываем поток для чтения файла f , потребуется массив равный кол-ву четных элементов файла на четность можно проверить если остаток от деления числа на 2 =0 то
число четное , далее просто заполняем массив из файла четными точно такой же проверкой и выводим в файл g . Но еще лучше использовать динамический массив тогда проход по файлу будет равен 1
5)Все просто открываешь первый файл для чтение считаешь кол-во элементов ,
создаешь массив, кол-во элементов которого = твой подсчет , заполняешь его из файла ,далее соритруешь по возрастанию , и выводишь этот массив в файл 2 , опять же можешь использовать динамические массивы и облегчить себе жизнь
Var
i,k,s:integer;
begin
k:=0; s:=0;
i:=7;
Writeln('Числа на интервале [7;100], кратные 7:');
while i<=100 do begin
Write(i,' ');
s:=s+i; Inc(k);
i:=i+7
end;
Writeln;
Writeln('Сумма этих чисел равна ',s,', количество равно ',k);
end.
Результат выполнения программы
Числа на интервале [7;100], кратные 7:
7 14 21 28 35 42 49 56 63 70 77 84 91 98
Сумма этих чисел равна 735, количество равно 14
Ван нужно перевести килобайты в байты?
0,25 Кб = 256 б