You are placed on a 5 × 5 grid at ( 0 , 0 ) . You aim to get to the opposite corner at ( 5 , 5 ) by moving along the edges in the quickest time possible.
Each edge takes 1 minute to traverse.
The edges are initially randomly coloured Green and Red. You can only see the edges connected to your vertex, and can only travel along Green edges.
Every minute the edges swap colours.
(eg you walk from ( 0 , 4 ) to ( 0 , 5 ) along a Green edge. When you finish walking the edge turns Red. You discover that the edge from ( 0 , 5 ) to ( 1 , 5 ) has also turned Red. You then have to wait 1 minute for the colours to change so you can move on).
The average fastest time to traverse from ( 0 , 0 ) to ( 5 , 5 ) can be expressed as 1 0 + n m , where m and n are coprime.
Find m + n .
See Crossing Roads
This section requires Javascript.
You are seeing this because something didn't load right. We suggest you, (a) try
refreshing the page, (b) enabling javascript if it is disabled on your browser and,
finally, (c)
loading the
non-javascript version of this page
. We're sorry about the hassle.
Although the strategy of "head for the diagonal if you have a choice" is intuitively reasonable, and certainly better than the "if you have two choices, pick one randomly" strategy (which has expected time of 1 0 + 5 1 2 1 5 9 5 > 1 0 + 6 5 5 3 6 1 8 7 5 6 3 ), we really need a proof that this is the optimal strategy.
Log in to reply
True. For this question, it's clear to see that you are just choosing the lowest expected value from those up and right. Which in all cases above is towards the diagonal.
It can be proved formally with induction that in the upper-left half: Right ≤ Up and Up ≤ 1 + Right.
Can write out both proofs later on if time allows.
To simplify the computations, I reversed the direction of the path, so I'm at ( 5 , 5 ) going towards ( 0 , 0 ) I created a matrix of expected walking times towards ( 0 , 0 )
Note P [ 0 , 0 ] = 0 .
Along horizontal and vertical boundaries of the grid, I assumed the optimal strategy would be to head straight towards ( 0 , 0 ) . (This is easily verified.) Thus P [ j , 0 ] = P [ 0 , j ] = ( 3 / 2 ) + P [ j + 1 , 0 ] for 1 ≤ j ≤ 6 .
When at a boundary, one can move directly immediately with probability 1 / 2 , and must wait an extra minute with probability 1/2. Hence the " 3 / 2 ".
For 1 ≤ i , j ≤ 5 , we use a strategy of trying to head towards the diagonal immediately, whenever possible. If not, then one should move immediately, if possible. If both paths are red, then one waits a turn and heads toward the diagonal.
This yields a recursive relationship P [ i , j ] = 0 . 5 ( 1 + min ( P [ i − 1 , j ] , P [ i , j − 1 ] ) + 0 . 2 5 ( 1 + max ( P [ i − 1 , j ] , P [ i , j − 1 ] ) ) + 0 . 2 5 ( 2 + min ( P [ i − 1 , j ] , P [ i , j − 1 ] ) )
In decimal form, the matrix P is
P = 0 . 0 0 0 0 0 0 0 0 1 . 5 0 0 0 0 0 0 0 3 . 0 0 0 0 0 0 0 0 4 . 5 0 0 0 0 0 0 0 6 . 0 0 0 0 0 0 0 0 7 . 5 0 0 0 0 0 0 0 1 . 5 0 0 0 0 0 0 0 2 . 7 5 0 0 0 0 0 0 4 . 0 6 2 5 0 0 0 0 5 . 4 2 1 8 7 5 0 0 6 . 8 1 6 4 0 6 2 5 8 . 2 3 7 3 0 4 6 9 3 . 0 0 0 0 0 0 0 0 4 . 0 6 2 5 0 0 0 0 5 . 3 1 2 5 0 0 0 0 6 . 5 8 9 8 4 3 7 5 7 . 8 9 6 4 8 4 3 8 9 . 2 3 1 6 8 9 4 5 4 . 5 0 0 0 0 0 0 0 5 . 4 2 1 8 7 5 0 0 6 . 5 8 9 8 4 3 7 5 7 . 8 3 9 8 4 3 7 5 9 . 1 0 4 0 0 3 9 1 1 0 . 3 8 5 9 2 5 2 9 6 . 0 0 0 0 0 0 0 0 6 . 8 1 6 4 0 6 2 5 7 . 8 9 6 4 8 4 3 8 9 . 1 0 4 0 0 3 9 1 1 0 . 3 5 4 0 0 3 9 1 1 1 . 6 1 1 9 8 4 2 5 7 . 5 0 0 0 0 0 0 0 8 . 2 3 7 3 0 4 6 9 9 . 2 3 1 6 8 9 4 5 1 0 . 3 8 5 9 2 5 2 9 1 1 . 6 1 1 9 8 4 2 5 1 2 . 8 6 1 9 8 4 2 5
To get the final answer, convert P[5,5] - 10 to a fraction. I used the Python Fraction package:
Fraction(P[5,5]-10)
outputs
Fraction(187563, 65536)
And 1 8 7 5 6 3 + 6 5 5 3 6 = 2 5 3 0 9 9 .
As has already noted, the only way to approach this is iteratively from point (5,5). Ignoring the travelling time also helps simplify matters because we are interested only in working out how much time is "wasted".
The reason for using backwards iteration is that there is a choice involved at each junction if both North and East routes are available. For an optimal route we would choose the route that moves us to the point with lowest remaining expected "waste" - call it E(x,y). So calculating E(x,y) requires knowledge of E(x+1,y) and E(x,y+1).
Beyond that it is a fairly laborious exercise without a computer.
I was wondering if a closed form was easy to achieve. Making a new puzzle exploring this further.
Problem Loading...
Note Loading...
Set Loading...
Working backwards calculating the expected amount of time taken from each point, we get this: (All numbers present are numerators over 6 5 5 3 6 and ignore the 1 minute of walking between vertices).
1 6 3 8 4 0 1 4 6 6 2 4 1 4 6 2 5 6 1 5 6 3 6 4 1 7 1 1 7 9 1 8 7 5 6 3 1 3 1 0 7 2 1 1 9 0 4 0 1 2 4 2 8 8 1 3 7 8 8 8 1 5 4 2 7 2 − 9 8 3 0 4 9 3 1 8 4 1 0 4 1 9 2 1 2 0 5 7 6 − − 6 5 5 3 6 6 9 6 3 2 8 6 0 1 6 − − − 3 2 7 6 8 4 9 1 5 2 − − − − 0 − − − − −
Each value is calculated as (Time when move up) / 4 + 3 ∗ (Time when move right) / 4 + 1 6 3 8 4 , where 6 5 5 3 6 1 6 3 8 4 = 4 1 .
The top row is 3 2 7 6 8 + (Time when move right). And the middle diagonal is simplified to (Time when move up) + 1 6 3 8 4 .
The rest of the squares are reflections from symmetry.
The answer is 1 0 + 6 5 5 3 6 1 8 7 5 6 3 .
m + n = 1 8 7 5 6 3 + 6 5 5 3 6 = 2 5 3 0 9 9 .