#include <iostream>
using namespace std;
int main() {
const int M = 3;
const int N = 4;
int matrix [M][N] = {};
int k,s=0,pr=1;
cout << "Введите k:" << endl;
cin >> k;
for (int i = 0; i < M; i++) { //забиваем матрицу случайными числами
for (int j = 0; j < N; j++) {
matrix[i][j] = rand() % 10;
}
}
for (int i = 0; i < M; i++) { //находим сумму и произведение
s += matrix[i][k-1];
pr *= matrix[i][k-1];
}
for (int i = 0; i < M; i++) { //выводим матрицу на экран
for (int j = 0; j < N; j++) {
cout << matrix[i][j] << " ";
}
cout << endl;
}
cout << s << endl << pr; //выводим на экран сумму и произведение элементов
return 0;
}
Решение.
Количество путей до города Х = количество путей добраться в любой из тех городов, из которых есть дорога в Х.
При этом если путь должен не проходить через какой-то город, нужно просто не учитывать этот город при подсчёте сумм. А если город наоборот обязательно должен лежать на пути, тогда для городов, в которые из нужного города идут дороги, в суммах нужно брать только этот город.
С помощью этого наблюдения посчитаем последовательно количество путей до каждого из городов:
А = 1
Б = А = 1
Д = А = 1
Г = А + Д = 1 + 1 = 2
В = А + Б + Г = 4
Е = В = 4
Ж = В + Е = 4 + 4 = 8
З = 0 (поскольку в З не ведёт ни одна дорога из В)
И = Е + Ж = 4 + 8 = 12.
Приведем другое решение.
Количество путей из города А в город И, проходящих через город В, равно произведению количества путей из города А в город В и количества путей из города В в город И.
Найдем количество путей из города А в город В:
А = 1
Б = А = 1
Д = А = 1
Г = А + Д = 1 + 1 = 2
В = А + Б + Г = 4.
Найдем количество путей из города В в город И (при этом В - исходный пункт):
В = 1
Е = В = 1
Ж = В + Е = 1 + 1 = 2
И = Е + Ж = 1 + 2 = 3.
Тогда количество путей из города А в город И, проходящих через город В, равно 4 · 3 = 12.
Примечание. Необходимо найти количество различных путей из города А в город И, проходящих через город В.
ответ: 12.
var
a,b,c,d: real;
s,r,p:real;
begin
a: = 1;
b: = 2;
c:= 3;
d:=4;
s:= a+b+c+d;
r:= a - b - c -d; //не совсем корректно сформулированно задание
p:= a*b*c*d;
writeln(s,' ',r,' ',p);
end;
//C
#include <stdio.h>
int main()
{
double a,b,c,d;
a = 1;
b = 2;
c = 3;
d = 4;
double s,r,p;
s = a + b + c + d;
r = a - b - c - d;
p = a * b * c * d;
printf("%f %f %f",s,r,p);
}