laziness, impatience, and hubris | |
PerlMonks |
Re^5: Highest total sum path problemby bliako (Monsignor) |
on Mar 04, 2020 at 18:40 UTC ( [id://11113779]=note: print w/replies, xml ) | Need Help?? |
OK. But something does not add up: You can slide over negative values, essentially ignoring them. They have no effect whatsoever! right? Oh except when they are on a turning. Here are some more questions to rubber-duck it Do you know your matrix fully in advance? Or do you have to query it as you move along? Because it may be too expensive to evaluate or store the full matrix, for example evaluating a function in 10-decimal accuracy. Do you have to find the best solution or can you use a heuristic like genetic algorithms which may find a good solution in short time by skipping some (possibly better) solutions? If so, one simple heuristic is to start first with those squares with large points and slide through them. Or plan a path which includes most valueable squares and no negatives. Completely ignoring the small ones and hoping for the best! More concretely, here is a top-down rather than bottom-up approach: first sort your squares wrt value and this will determine your visitation priority. Then construct a path-builder to suggest paths given these top-priority, must-visit squares. Btw, it reminds me of Gradient Descent (or Hill Climbing). It still suffers from local minima but there are some better alternatives out there fo exploring a neighbourhood and avoiding local minima ... In any case I thought perhaps you can cache path segments you visit so that you do not have to re-sum. bw, bliako
In Section
Seekers of Perl Wisdom
|
|