На рисунке представлена схема дорог, связывающих города A, B, C, D, E, F, G, H, K, X, J, Q, P, L, M, O, N. По каждой дороге можно двигаться только в одном направлении, указанном стрелкой.
Сколько существует различных путей из города A в город N, не проходящих через город K?
Решать будем динамикой.
Зачеркнём те дороги, по которым нам двигаться нельзя. (Те, которые идут в город K или выходят из него)
Красным отмечено, сколько путей идёт в конкретную вершину по конкретной стрелке. Заметим, что если в город идёт более, чем одна дорога, значит количество путей в этот город будет равно сумме количеств путей, ведущих в города, из которых эти дороги начинаются. В этом и есть принцип динамического решения. Получается, если сложить все красные числа, нарисованные около конкретного города, как раз можно получить количество различных путей, ведущих в этот город.
Если по дороге двигаться запрещено, количество путей, проходящих через неё равно нулю.
Нужно понимать, что в город A можно попасть одним путём: собственно, никуда не уходить из города A.
Также заметим, что на графе присутствуют лишние дороги, не ведущие в город N, которые нам не нужны, и пути по которым считать не надо.
Итого получается, что в пункт N ведут 36 различных путей.