49 of 100: Mathematical Meandering

Logic Level 2

Zara is finding her way home, but she wants to take a route that visits her neighborhood as much as possible. From any square on the map shown, she can move up, down, left, or right a square (not diagonally).

She also wants to visit every empty square exactly once , entirely avoid the squares marked with "under construction" signs, and she wants her trip to end at her house.

Is it possible for her to do this?

You can just start drawing paths, or you can use logic!

Yes, the trip is possible No, she has to revisit at least one of the squares at least once

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.

13 solutions

Mark Dawes
Jul 19, 2017

One way to start is to focus on the squares that only have two ways they can be accessed. These are shown with a star:

Now let's draw in the part of the route that these imply. If it's going to be possible to make a full route then it must include these.

Now there are some new squares that only have two access points. They are shown with a star:

Put the route-fragments in for these too.

Repeat the process ...

... until finished:

Great logical deduction!

Calvin Lin Staff - 3 years, 10 months ago

Beautifully clear explanation! This is how I solved it. It is amazing to see how the apparently many path options quickly narrow to one.

Mark Lama - 3 years, 10 months ago

Missed this one, but happy to learn your method :)

Andrew Lamoureux - 3 years, 10 months ago

That is beautiful

Katherine barker - 3 years, 10 months ago
Giles Haynes
Jul 18, 2017

A clear, precise solution is always best!

William Huang - 3 years, 10 months ago

It's not hard to show this is the only path. We only need that the path is fixed at every corner.

Anthony Cutler - 3 years, 10 months ago
Sharky Kesa
Jul 18, 2017

This was a Hamiltonian paths problem. I tried to find all such paths, and determined that there was only one such way of doing so. I created a script that found all Hamiltonian paths between two points on a graph, as can be demonstrated below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
connections1 = {'A1': ['A2', 'B1'], 'A2': ['A1', 'A3'], 'A3': ['A2', 'A4',  'B3'], 'A4': ['A3', 'A5', 'B4'], 'A5': ['A4', 'A6'], 'A6': ['A5', 'B6'], 
'B1': ['A1', 'B3', 'C1'], 'B3': ['A3', 'B4', 'C3'], 'B4': ['A4', 'B3', 'C4'],  'B6': ['A6', 'C6'], 
'C1': ['B1', 'C2', 'D1'], 'C2': ['C1', 'C3', 'D2'], 'C3': ['B3', 'C2', 'C4', 'D3'], 'C4': ['B4', 'C3', 'C5', 'D4'], 'C5': ['C4', 'C6', 'D5'], 'C6': ['B6', 'C5', 'D6'], 
'D1': ['C1', 'D2', 'E1'], 'D2': ['C2', 'D1', 'D3', 'E2'], 'D3': ['C3', 'D2', 'D4'], 'D4': ['C4', 'D3', 'D5', 'E4'], 'D5': ['C5', 'D4', 'D6', 'E5'], 'D6': ['C6', 'D5'], 
'E1': ['D1', 'E2', 'F1'], 'E2': ['D2', 'E1', 'F2'], 'E4': ['D4', 'E5', 'F4'], 'E5': ['D5', 'E4', 'F5'],  
'F1': ['E1', 'F2'], 'F2': ['E2', 'F1', 'F3'], 'F3': ['F2', 'F4'], 'F4': ['E4', 'F3', 'F5'], 'F5': ['E5', 'F4', 'F6'], 'F6': ['F5']}

def find_all_paths(graph, start, end, path=[]):
    path = path + [start]
    if start == end:
        return [path]
    paths = []
    for node in graph[start]:
        if node not in path:
            newpaths = find_all_paths(graph, node, end, path)
            for newpath in newpaths:
              if len(newpath)==len(graph):
                  paths.append(newpath)
    return paths

set=[]
set.append(find_all_paths(connections1, 'B1', 'F6'))

print(set)
print(len([j for i in set for j in i]))

I used a chessboard labelling to identify each square (letters at the bottom, numbers on the side). This outputs

1
2
[[['B1', 'A1', 'A2', 'A3', 'B3', 'B4', 'A4', 'A5', 'A6', 'B6', 'C6', 'D6', 'D5', 'C5', 'C4', 'D4', 'D3', 'C3', 'C2', 'C1', 'D1', 'D2', 'E2', 'E1', 'F1', 'F2', 'F3', 'F4', 'E4', 'E5', 'F5', 'F6']]]
1

Its really confusing

Jasim Mahmood - 3 years, 10 months ago

I for one appreciate the programming approaches, as there are usually many ways to approach the problem. Sharky's solution uses a Python Pattern associated with Graph Theory. Recognizing patterns is a key to becoming a good problem solver, whether or not code is used. And thanks to this, I have a new technique in the tool box.

With this algorithm, it would now be very easy to find out which squares Zara could start from that do not have a solution.

What would be cool is to generalize the program by building of the connections1 dictionary from the board configuration and the list of forbidden squares.

Really cool would be to incorporate Mark Dawes recursive two-way square partial paths algorithm to help solve really big problems.

Stephen Rasey - 3 years, 9 months ago

Using a computer to do brute force, is still brute force.

Robert DeLisle - 3 years, 10 months ago

Log in to reply

I never claimed it wasn't brute force. I saw the path easily, but I wanted to determine all such paths. Using a computer made this much easier.

Sharky Kesa - 3 years, 10 months ago

I don't think Sharky claimed otherwise

Alex Li - 3 years, 10 months ago
Mark Hennings
Jul 19, 2017

It is quite fun to see that there is only one solution. There is only one way of getting into and out of a corner square. This applies to either a true corner square or a pattern of squares that is essentially a corner created either by blocked squares or squares already visited.

We start as in the left picture, showing how the path must go through the obvious corners. We then proceed to make forced joins between path sections, and fill in newly created corner turns. Doing this successively as shown, we end up with the RH diagram as the only solution.

Stefano Gallenda
Jul 19, 2017

But I don't know if this is the only possible path.

I found it easy if one started at the house and worked backward to Zara. Edwin Gray

Edwin Gray - 3 years, 10 months ago
Wesley Zumino
Jul 21, 2017

I used a constructive graph-theoretic approach. Sharing it for those interested. It looks equivalent to @Mark Dawes ' solution. (Well done, Mark.) Start by creating a graph G G from the problem.

Problem: In graph G G , construct an S \rightarrow F path P P that visits every node (at most once, by definition of a path ).
Fact: each node in P P except S and F is required to have degree 2 (i.e., be between exactly 2 path edges), while deg(S) = 1 = deg(F) in P P .

Iterate by alternately adding or eliminating possible path edges from G G as follows:

(A) Add non-path edges from G G to P P if those edges are the only way to satisfy a node’s degree requirement in P P .

(E) Eliminate all non-path edges from G G at each node if the node’s degree requirement in P P has been satisfied.

STOP if either all node degree requirements are met (path found) or no more non-path edges can be added or eliminated (no path possible).

Algorithm iterates are shown below where edges in red are added or eliminated based on the degree requirements of red nodes.

This construction also shows the path is unique.

This is very clear - I like it a lot. It's also a more formal way to do it. Thanks for taking the time to create the diagrams (which is a time-consuming job!).

Mark Dawes - 3 years, 10 months ago
Alec White
Jun 9, 2018

Junyi Liu
Sep 7, 2017

Kalib Perry
Apr 14, 2020

she could because she could go left up and left.(

Calvin Godfrey
Sep 17, 2017

I don't know if this is valid reasoning, but this is what I did.

I overlaid a checkerboard pattern on top of the grid. Whenever Zara moves from one square to another, the color of the square must change. Of the squares that are "under construction", there is a pair that is one color and a pair that is the other color. This means that there is an equal number of squares of each color remaining, and there is a valid path.

Akshay Gupta
Jul 24, 2017

Roy Han
Jul 19, 2017

Imagine the grid as a chess board with the home being black. Then Zara is starting on a white space. This means she must take an odd number of steps to finish on a black space. There are 36 spaces on the board, meaning 35 steps to cover the entire board. Taking the construction into consideration, we subtract 4 from 35 to give Zara 31 steps, meaning she will end on a black space hence making it possible.

You have found a necessary condition for such a path to exist. Unfortunately, it need not be sufficient. Do you see why?

Calvin Lin Staff - 3 years, 10 months ago

Log in to reply

Oh I guess if the construction completely blocked off the home this would still say you could even thought it would be impossible.

Roy Han - 3 years, 10 months ago

Log in to reply

Good observation. Are there other scenarios where we remove 2 black and 2 white squares such that home isn't completely blocked off (meaning that there is always a path from home to any unremoved square), but such a path visiting every empty square exactly once doesn't exist?

Calvin Lin Staff - 3 years, 10 months ago

Log in to reply

@Calvin Lin Yup cases where construction would force Zara to visit the starting square again. Didn't realize any of this at the moment haha.

Roy Han - 3 years, 10 months ago

Log in to reply

@Roy Han Indeed! For example, if the starting square was ( 1 , 1 ) (1,1) , and the square ( 2 , 2 ) (2,2) was blocked, then there isn't a way to visit both of ( 1 , 2 ) (1,2) and ( 2 , 1 ) (2,1) .

Learn something new every day :)

Calvin Lin Staff - 3 years, 10 months ago

But this does do the job of telling you that it is worth trying at least. Had you had 5 construction spaces, it would have proven there is no point in trying.

Peter Newcomb - 3 years, 10 months ago
Chandan Kumar
Jul 19, 2017

Think it opposite, ie from home to its initial position

0 pending reports

×

Problem Loading...

Note Loading...

Set Loading...