Skip to content

Latest commit

 

History

History
40 lines (23 loc) · 1.22 KB

README.md

File metadata and controls

40 lines (23 loc) · 1.22 KB

$\huge\color{cadetblue}{\text{Square-sum Problem}}$


The problem as explained by Matt Parker:

Problem


${\Large\color{rosybrown}\text{Program usage}}$

The program makes use of a backtracking algorithm, guided by a heuristic that prioritizes vertices having the least degree (i.e. the least number of edges connecting them to the remaining unvisited ones) in order to avoid potential dead ends. The program is capable of computing Hamiltonian paths for inputs up to 20'000 relatively easily. If no path exists, the output is None.


${\large\color{darkseagreen}\text{Example input}}$

python3 squaresum.py 23

${\large\color{darkseagreen}\text{Example output}}$

[18, 7, 9, 16, 20, 5, 11, 14, 2, 23, 13, 12, 4, 21, 15, 10, 6, 19, 17, 8, 1, 3, 22]

If this example leaves you with an appetite for more, have a look at the Hamiltonian path for 21'000: path.

Please note that for large paths, you may have to increase the stack size in order to avoid a segmentation fault. This can be done in the terminal:

ulimit -s unlimited