Maximize Path ValueMore optimized approach of Dijkstra's algorithmShortest path navigation across a grid using Best First SearchParse WAP-230 “variable length unsigned integers”Finding the maximal bottleneck in a 2D matrix from source to destinationFind the longest rectilinear path in a matrix with descending entriesFinding nodes around a given node in a gridGiven a binary tree, find the maximum path sumSplit list of integers at certain value efficientlyBFS to check if path from start node to end node existsGoogle FooBar “Prepare The Bunnies Escape”

Knowledge-based authentication using Domain-driven Design in C#

How can I deal with my CEO asking me to hire someone with a higher salary than me, a co-founder?

Mathematica command that allows it to read my intentions

What reasons are there for a Capitalist to oppose a 100% inheritance tax?

Is there a hemisphere-neutral way of specifying a season?

Avoiding the "not like other girls" trope?

How do I exit BASH while loop using modulus operator?

my venezuela girlfriend wants to travel the USA where i live.what does she need to do and how expensive will it become or how difficult?

How can saying a song's name be a copyright violation?

How to prevent "they're falling in love" trope

What is the opposite of "eschatology"?

In the UK, is it possible to get a referendum by a court decision?

How dangerous is XSS

What is an equivalently powerful replacement spell for the Yuan-Ti's Suggestion spell?

Was the old ablative pronoun "med" or "mēd"?

Why was the shrink from 8″ made only to 5.25″ and not smaller (4″ or less)

Is it possible to create a QR code using text?

What historical events would have to change in order to make 19th century "steampunk" technology possible?

How badly should I try to prevent a user from XSSing themselves?

Bullying boss launched a smear campaign and made me unemployable

Could the museum Saturn V's be refitted for one more flight?

What is the fastest integer factorization to break RSA?

What are the G forces leaving Earth orbit?

Does Dispel Magic work on Tiny Hut?



Maximize Path Value


More optimized approach of Dijkstra's algorithmShortest path navigation across a grid using Best First SearchParse WAP-230 “variable length unsigned integers”Finding the maximal bottleneck in a 2D matrix from source to destinationFind the longest rectilinear path in a matrix with descending entriesFinding nodes around a given node in a gridGiven a binary tree, find the maximum path sumSplit list of integers at certain value efficientlyBFS to check if path from start node to end node existsGoogle FooBar “Prepare The Bunnies Escape”













1












$begingroup$


I recently had to code an algorithm that will, for an input of: matrix of up to 5x5 size and a defined path length, find a path of this given length from the first top left matrix element (0, 0) to the last bottom right element (n, n). The desired path is the one which maximizes the sum of matrix elements along the path. After reading about common path finding algorithms like Dijkstra or A* and DFS vs. BFS, here is what I've come up with:



def gridsum(grid):
"""Calculates sum of all grid elements"""
s = 0
for el in grid:
s += sum(el)
return s

def longpaths(grid, path):
"""Function to calculate best path for long paths with respect to no. of grid elements"""
# For path length equal to number of grid elements, the solution is trivial:
if path == len(grid)*len(grid[0]):
return gridsum(grid)

# Not sure down to which path length this works..?
if path+1 == len(grid)*len(grid[0]):
s = gridsum(grid)
del grid[0][0]
del grid[len(grid)-1][len(grid[-1])-1]
return s - min(sum(grid, []))

if path+2 == len(grid)*len(grid[0]):
s = gridsum(grid)
del grid[0][0]
del grid[len(grid)-1][len(grid[-1])-1]
m1 = min(sum(grid, []))
s -= m1
for i in range(len(grid)):
if m1 in grid[i]:
gindexm1 = i
grid[gindexm1].remove(m1)
return s - min(sum(grid, []))

class Node():
def __init__(self, parent=None, position=None, value=0):
self.position = position # a tuple representing the indices in grid
self.value = value # grid position value
self.cpl = 0 # current path length
self.cpv = 0 # current path value
self.parents = [parent]
if parent is not None:
for el in parent.parents:
self.parents.append(el)

def __eq__(self, other):
return self.position == other.position

def minsteps(grid, position):
"""Calculates the minimum number of steps necessary to reach target node"""
steps = 0
x, y = position[0], position[1]
while x < len(grid)-1 and y < len(grid[0])-1:
x, y, steps = x+1, y+1, steps+1
while x < len(grid)-1:
x, steps = x+1, steps+1
while y < len(grid[0])-1:
y, steps = y+1, steps+1
return steps

def g_key(grid, path):
# For long paths relative to amount of grid elements, solution is simple
if path+2 >= len(grid)*len(grid[0]):
return longpaths(grid, path)

# Create start and end node
start_node = Node(None, (0, 0), grid[0][0])
start_node.cpv = start_node.value
start_node.cpl = 1
end_node = Node(None, (len(grid)-1, len(grid[0])-1), grid[len(grid)-1][len(grid[0])-1])

# Add a node queue to loop through, start node has not been previously visited
queued_nodes = [start_node]
previously_visited = None
final_path_values = []

while len(queued_nodes) > 0:

# Set current node to first element of queued nodes
current_node = queued_nodes[0]

# If target is unreachable within path length restrictions, skip calculation of this node
if path-current_node.cpl < minsteps(grid, current_node.position):
queued_nodes.remove(current_node)
continue

# Add all paths with length path that end at the final node to final paths list
if current_node.cpl == path:
if current_node == end_node:
final_path_values.append(current_node.cpv)
queued_nodes.remove(current_node)
continue

# Generate child nodes to current node, make sure new nodes are within grid and
# have not been visited within the current path, then add them to the node queue
children = []
for new_position in [(0, -1), (0, 1), (-1, 0), (1, 0), (-1, -1), (-1, 1), (1, -1), (1, 1)]: # adjacent grid elements
node_position = (current_node.position[0] + new_position[0], current_node.position[1] + new_position[1])
if any((node_position[0] < 0, node_position[1] < 0, node_position[0] > len(grid)-1, node_position[1] > len(grid[0])-1)):
continue
new_child = Node(current_node, node_position, grid[node_position[0]][node_position[1]])
for parent in new_child.parents:
if parent is not None:
if node_position == parent.position:
previously_visited = True
if previously_visited:
previously_visited = False
continue
children.append(new_child)
queued_nodes.append(new_child)

# Update current path length and value for children
for child in children:
child.cpl = current_node.cpl + 1
child.cpv = current_node.cpv + child.value

# Calculation for this node done, remove it from queue
queued_nodes.remove(current_node)

return max(final_path_values)


For an input of:



g_key([[1, 6, 7, 2, 4],
[0, 4, 9, 5, 3],
[7, 2, 5, 1, 4],
[3, 3, 2, 2, 9],
[2, 6, 1, 4, 0]], 9)


this code finds the correct solution of 46.



However, this algorithm is incredibly slow, as I think it scales with $O(n^m)$, where n = matrix size and m = path length, and memory intensive since every node has to keep track of every parent/grandparent/great-grandparent node it has to prevent visiting matrix elements multiple times within each path. That is why I had to add the longpaths function to get reasonable runtimes for long paths.



Is there any way to speed this up or at least make it less memory intensive? I have found plenty of documentation how to do this if we just wanted to minimize the path length, but since in this case we want to maximize the path value while keeping a constant path length, I haven't been able to come up with a way to improve on what is basically a brute-force method of calculating everything.










share|improve this question









New contributor




SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







$endgroup$
















    1












    $begingroup$


    I recently had to code an algorithm that will, for an input of: matrix of up to 5x5 size and a defined path length, find a path of this given length from the first top left matrix element (0, 0) to the last bottom right element (n, n). The desired path is the one which maximizes the sum of matrix elements along the path. After reading about common path finding algorithms like Dijkstra or A* and DFS vs. BFS, here is what I've come up with:



    def gridsum(grid):
    """Calculates sum of all grid elements"""
    s = 0
    for el in grid:
    s += sum(el)
    return s

    def longpaths(grid, path):
    """Function to calculate best path for long paths with respect to no. of grid elements"""
    # For path length equal to number of grid elements, the solution is trivial:
    if path == len(grid)*len(grid[0]):
    return gridsum(grid)

    # Not sure down to which path length this works..?
    if path+1 == len(grid)*len(grid[0]):
    s = gridsum(grid)
    del grid[0][0]
    del grid[len(grid)-1][len(grid[-1])-1]
    return s - min(sum(grid, []))

    if path+2 == len(grid)*len(grid[0]):
    s = gridsum(grid)
    del grid[0][0]
    del grid[len(grid)-1][len(grid[-1])-1]
    m1 = min(sum(grid, []))
    s -= m1
    for i in range(len(grid)):
    if m1 in grid[i]:
    gindexm1 = i
    grid[gindexm1].remove(m1)
    return s - min(sum(grid, []))

    class Node():
    def __init__(self, parent=None, position=None, value=0):
    self.position = position # a tuple representing the indices in grid
    self.value = value # grid position value
    self.cpl = 0 # current path length
    self.cpv = 0 # current path value
    self.parents = [parent]
    if parent is not None:
    for el in parent.parents:
    self.parents.append(el)

    def __eq__(self, other):
    return self.position == other.position

    def minsteps(grid, position):
    """Calculates the minimum number of steps necessary to reach target node"""
    steps = 0
    x, y = position[0], position[1]
    while x < len(grid)-1 and y < len(grid[0])-1:
    x, y, steps = x+1, y+1, steps+1
    while x < len(grid)-1:
    x, steps = x+1, steps+1
    while y < len(grid[0])-1:
    y, steps = y+1, steps+1
    return steps

    def g_key(grid, path):
    # For long paths relative to amount of grid elements, solution is simple
    if path+2 >= len(grid)*len(grid[0]):
    return longpaths(grid, path)

    # Create start and end node
    start_node = Node(None, (0, 0), grid[0][0])
    start_node.cpv = start_node.value
    start_node.cpl = 1
    end_node = Node(None, (len(grid)-1, len(grid[0])-1), grid[len(grid)-1][len(grid[0])-1])

    # Add a node queue to loop through, start node has not been previously visited
    queued_nodes = [start_node]
    previously_visited = None
    final_path_values = []

    while len(queued_nodes) > 0:

    # Set current node to first element of queued nodes
    current_node = queued_nodes[0]

    # If target is unreachable within path length restrictions, skip calculation of this node
    if path-current_node.cpl < minsteps(grid, current_node.position):
    queued_nodes.remove(current_node)
    continue

    # Add all paths with length path that end at the final node to final paths list
    if current_node.cpl == path:
    if current_node == end_node:
    final_path_values.append(current_node.cpv)
    queued_nodes.remove(current_node)
    continue

    # Generate child nodes to current node, make sure new nodes are within grid and
    # have not been visited within the current path, then add them to the node queue
    children = []
    for new_position in [(0, -1), (0, 1), (-1, 0), (1, 0), (-1, -1), (-1, 1), (1, -1), (1, 1)]: # adjacent grid elements
    node_position = (current_node.position[0] + new_position[0], current_node.position[1] + new_position[1])
    if any((node_position[0] < 0, node_position[1] < 0, node_position[0] > len(grid)-1, node_position[1] > len(grid[0])-1)):
    continue
    new_child = Node(current_node, node_position, grid[node_position[0]][node_position[1]])
    for parent in new_child.parents:
    if parent is not None:
    if node_position == parent.position:
    previously_visited = True
    if previously_visited:
    previously_visited = False
    continue
    children.append(new_child)
    queued_nodes.append(new_child)

    # Update current path length and value for children
    for child in children:
    child.cpl = current_node.cpl + 1
    child.cpv = current_node.cpv + child.value

    # Calculation for this node done, remove it from queue
    queued_nodes.remove(current_node)

    return max(final_path_values)


    For an input of:



    g_key([[1, 6, 7, 2, 4],
    [0, 4, 9, 5, 3],
    [7, 2, 5, 1, 4],
    [3, 3, 2, 2, 9],
    [2, 6, 1, 4, 0]], 9)


    this code finds the correct solution of 46.



    However, this algorithm is incredibly slow, as I think it scales with $O(n^m)$, where n = matrix size and m = path length, and memory intensive since every node has to keep track of every parent/grandparent/great-grandparent node it has to prevent visiting matrix elements multiple times within each path. That is why I had to add the longpaths function to get reasonable runtimes for long paths.



    Is there any way to speed this up or at least make it less memory intensive? I have found plenty of documentation how to do this if we just wanted to minimize the path length, but since in this case we want to maximize the path value while keeping a constant path length, I haven't been able to come up with a way to improve on what is basically a brute-force method of calculating everything.










    share|improve this question









    New contributor




    SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.







    $endgroup$














      1












      1








      1





      $begingroup$


      I recently had to code an algorithm that will, for an input of: matrix of up to 5x5 size and a defined path length, find a path of this given length from the first top left matrix element (0, 0) to the last bottom right element (n, n). The desired path is the one which maximizes the sum of matrix elements along the path. After reading about common path finding algorithms like Dijkstra or A* and DFS vs. BFS, here is what I've come up with:



      def gridsum(grid):
      """Calculates sum of all grid elements"""
      s = 0
      for el in grid:
      s += sum(el)
      return s

      def longpaths(grid, path):
      """Function to calculate best path for long paths with respect to no. of grid elements"""
      # For path length equal to number of grid elements, the solution is trivial:
      if path == len(grid)*len(grid[0]):
      return gridsum(grid)

      # Not sure down to which path length this works..?
      if path+1 == len(grid)*len(grid[0]):
      s = gridsum(grid)
      del grid[0][0]
      del grid[len(grid)-1][len(grid[-1])-1]
      return s - min(sum(grid, []))

      if path+2 == len(grid)*len(grid[0]):
      s = gridsum(grid)
      del grid[0][0]
      del grid[len(grid)-1][len(grid[-1])-1]
      m1 = min(sum(grid, []))
      s -= m1
      for i in range(len(grid)):
      if m1 in grid[i]:
      gindexm1 = i
      grid[gindexm1].remove(m1)
      return s - min(sum(grid, []))

      class Node():
      def __init__(self, parent=None, position=None, value=0):
      self.position = position # a tuple representing the indices in grid
      self.value = value # grid position value
      self.cpl = 0 # current path length
      self.cpv = 0 # current path value
      self.parents = [parent]
      if parent is not None:
      for el in parent.parents:
      self.parents.append(el)

      def __eq__(self, other):
      return self.position == other.position

      def minsteps(grid, position):
      """Calculates the minimum number of steps necessary to reach target node"""
      steps = 0
      x, y = position[0], position[1]
      while x < len(grid)-1 and y < len(grid[0])-1:
      x, y, steps = x+1, y+1, steps+1
      while x < len(grid)-1:
      x, steps = x+1, steps+1
      while y < len(grid[0])-1:
      y, steps = y+1, steps+1
      return steps

      def g_key(grid, path):
      # For long paths relative to amount of grid elements, solution is simple
      if path+2 >= len(grid)*len(grid[0]):
      return longpaths(grid, path)

      # Create start and end node
      start_node = Node(None, (0, 0), grid[0][0])
      start_node.cpv = start_node.value
      start_node.cpl = 1
      end_node = Node(None, (len(grid)-1, len(grid[0])-1), grid[len(grid)-1][len(grid[0])-1])

      # Add a node queue to loop through, start node has not been previously visited
      queued_nodes = [start_node]
      previously_visited = None
      final_path_values = []

      while len(queued_nodes) > 0:

      # Set current node to first element of queued nodes
      current_node = queued_nodes[0]

      # If target is unreachable within path length restrictions, skip calculation of this node
      if path-current_node.cpl < minsteps(grid, current_node.position):
      queued_nodes.remove(current_node)
      continue

      # Add all paths with length path that end at the final node to final paths list
      if current_node.cpl == path:
      if current_node == end_node:
      final_path_values.append(current_node.cpv)
      queued_nodes.remove(current_node)
      continue

      # Generate child nodes to current node, make sure new nodes are within grid and
      # have not been visited within the current path, then add them to the node queue
      children = []
      for new_position in [(0, -1), (0, 1), (-1, 0), (1, 0), (-1, -1), (-1, 1), (1, -1), (1, 1)]: # adjacent grid elements
      node_position = (current_node.position[0] + new_position[0], current_node.position[1] + new_position[1])
      if any((node_position[0] < 0, node_position[1] < 0, node_position[0] > len(grid)-1, node_position[1] > len(grid[0])-1)):
      continue
      new_child = Node(current_node, node_position, grid[node_position[0]][node_position[1]])
      for parent in new_child.parents:
      if parent is not None:
      if node_position == parent.position:
      previously_visited = True
      if previously_visited:
      previously_visited = False
      continue
      children.append(new_child)
      queued_nodes.append(new_child)

      # Update current path length and value for children
      for child in children:
      child.cpl = current_node.cpl + 1
      child.cpv = current_node.cpv + child.value

      # Calculation for this node done, remove it from queue
      queued_nodes.remove(current_node)

      return max(final_path_values)


      For an input of:



      g_key([[1, 6, 7, 2, 4],
      [0, 4, 9, 5, 3],
      [7, 2, 5, 1, 4],
      [3, 3, 2, 2, 9],
      [2, 6, 1, 4, 0]], 9)


      this code finds the correct solution of 46.



      However, this algorithm is incredibly slow, as I think it scales with $O(n^m)$, where n = matrix size and m = path length, and memory intensive since every node has to keep track of every parent/grandparent/great-grandparent node it has to prevent visiting matrix elements multiple times within each path. That is why I had to add the longpaths function to get reasonable runtimes for long paths.



      Is there any way to speed this up or at least make it less memory intensive? I have found plenty of documentation how to do this if we just wanted to minimize the path length, but since in this case we want to maximize the path value while keeping a constant path length, I haven't been able to come up with a way to improve on what is basically a brute-force method of calculating everything.










      share|improve this question









      New contributor




      SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.







      $endgroup$




      I recently had to code an algorithm that will, for an input of: matrix of up to 5x5 size and a defined path length, find a path of this given length from the first top left matrix element (0, 0) to the last bottom right element (n, n). The desired path is the one which maximizes the sum of matrix elements along the path. After reading about common path finding algorithms like Dijkstra or A* and DFS vs. BFS, here is what I've come up with:



      def gridsum(grid):
      """Calculates sum of all grid elements"""
      s = 0
      for el in grid:
      s += sum(el)
      return s

      def longpaths(grid, path):
      """Function to calculate best path for long paths with respect to no. of grid elements"""
      # For path length equal to number of grid elements, the solution is trivial:
      if path == len(grid)*len(grid[0]):
      return gridsum(grid)

      # Not sure down to which path length this works..?
      if path+1 == len(grid)*len(grid[0]):
      s = gridsum(grid)
      del grid[0][0]
      del grid[len(grid)-1][len(grid[-1])-1]
      return s - min(sum(grid, []))

      if path+2 == len(grid)*len(grid[0]):
      s = gridsum(grid)
      del grid[0][0]
      del grid[len(grid)-1][len(grid[-1])-1]
      m1 = min(sum(grid, []))
      s -= m1
      for i in range(len(grid)):
      if m1 in grid[i]:
      gindexm1 = i
      grid[gindexm1].remove(m1)
      return s - min(sum(grid, []))

      class Node():
      def __init__(self, parent=None, position=None, value=0):
      self.position = position # a tuple representing the indices in grid
      self.value = value # grid position value
      self.cpl = 0 # current path length
      self.cpv = 0 # current path value
      self.parents = [parent]
      if parent is not None:
      for el in parent.parents:
      self.parents.append(el)

      def __eq__(self, other):
      return self.position == other.position

      def minsteps(grid, position):
      """Calculates the minimum number of steps necessary to reach target node"""
      steps = 0
      x, y = position[0], position[1]
      while x < len(grid)-1 and y < len(grid[0])-1:
      x, y, steps = x+1, y+1, steps+1
      while x < len(grid)-1:
      x, steps = x+1, steps+1
      while y < len(grid[0])-1:
      y, steps = y+1, steps+1
      return steps

      def g_key(grid, path):
      # For long paths relative to amount of grid elements, solution is simple
      if path+2 >= len(grid)*len(grid[0]):
      return longpaths(grid, path)

      # Create start and end node
      start_node = Node(None, (0, 0), grid[0][0])
      start_node.cpv = start_node.value
      start_node.cpl = 1
      end_node = Node(None, (len(grid)-1, len(grid[0])-1), grid[len(grid)-1][len(grid[0])-1])

      # Add a node queue to loop through, start node has not been previously visited
      queued_nodes = [start_node]
      previously_visited = None
      final_path_values = []

      while len(queued_nodes) > 0:

      # Set current node to first element of queued nodes
      current_node = queued_nodes[0]

      # If target is unreachable within path length restrictions, skip calculation of this node
      if path-current_node.cpl < minsteps(grid, current_node.position):
      queued_nodes.remove(current_node)
      continue

      # Add all paths with length path that end at the final node to final paths list
      if current_node.cpl == path:
      if current_node == end_node:
      final_path_values.append(current_node.cpv)
      queued_nodes.remove(current_node)
      continue

      # Generate child nodes to current node, make sure new nodes are within grid and
      # have not been visited within the current path, then add them to the node queue
      children = []
      for new_position in [(0, -1), (0, 1), (-1, 0), (1, 0), (-1, -1), (-1, 1), (1, -1), (1, 1)]: # adjacent grid elements
      node_position = (current_node.position[0] + new_position[0], current_node.position[1] + new_position[1])
      if any((node_position[0] < 0, node_position[1] < 0, node_position[0] > len(grid)-1, node_position[1] > len(grid[0])-1)):
      continue
      new_child = Node(current_node, node_position, grid[node_position[0]][node_position[1]])
      for parent in new_child.parents:
      if parent is not None:
      if node_position == parent.position:
      previously_visited = True
      if previously_visited:
      previously_visited = False
      continue
      children.append(new_child)
      queued_nodes.append(new_child)

      # Update current path length and value for children
      for child in children:
      child.cpl = current_node.cpl + 1
      child.cpv = current_node.cpv + child.value

      # Calculation for this node done, remove it from queue
      queued_nodes.remove(current_node)

      return max(final_path_values)


      For an input of:



      g_key([[1, 6, 7, 2, 4],
      [0, 4, 9, 5, 3],
      [7, 2, 5, 1, 4],
      [3, 3, 2, 2, 9],
      [2, 6, 1, 4, 0]], 9)


      this code finds the correct solution of 46.



      However, this algorithm is incredibly slow, as I think it scales with $O(n^m)$, where n = matrix size and m = path length, and memory intensive since every node has to keep track of every parent/grandparent/great-grandparent node it has to prevent visiting matrix elements multiple times within each path. That is why I had to add the longpaths function to get reasonable runtimes for long paths.



      Is there any way to speed this up or at least make it less memory intensive? I have found plenty of documentation how to do this if we just wanted to minimize the path length, but since in this case we want to maximize the path value while keeping a constant path length, I haven't been able to come up with a way to improve on what is basically a brute-force method of calculating everything.







      python performance graph pathfinding






      share|improve this question









      New contributor




      SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question









      New contributor




      SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question








      edited 3 mins ago









      Jamal

      30.6k11121227




      30.6k11121227






      New contributor




      SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 18 hours ago









      SquaricAcidSquaricAcid

      61




      61




      New contributor




      SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      SquaricAcid is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.




















          1 Answer
          1






          active

          oldest

          votes


















          0












          $begingroup$

          This is pretty easily solvable in O(n^2). Notice that any longest path from a to c with length >1 is a combination of a longest ab path and a longest bc path for some b. What you want to do here is to find the longest path to all squares using dynamic programming.






          share|improve this answer









          $endgroup$












          • $begingroup$
            The desired path length is given as input, we're interested in the path of this length that maximizes the sum of matrix elements it passes by (for the example input I provided, the path of length 9 is: (start: element (0, 0)) 1, 6, 7, 9, 5, 5, 4, 9, 0 (end: element (n, n)), the sum of which is 46). Breaking the problem down into smaller subproblems does not seem trivial to me, since the final solution for path length of x may be completely different from the final solution for path length of x-1 and thus not composed of the solutions for shorter paths.
            $endgroup$
            – SquaricAcid
            2 hours ago











          Your Answer





          StackExchange.ifUsing("editor", function ()
          return StackExchange.using("mathjaxEditing", function ()
          StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
          StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
          );
          );
          , "mathjax-editing");

          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "196"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );






          SquaricAcid is a new contributor. Be nice, and check out our Code of Conduct.









          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f216717%2fmaximize-path-value%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          0












          $begingroup$

          This is pretty easily solvable in O(n^2). Notice that any longest path from a to c with length >1 is a combination of a longest ab path and a longest bc path for some b. What you want to do here is to find the longest path to all squares using dynamic programming.






          share|improve this answer









          $endgroup$












          • $begingroup$
            The desired path length is given as input, we're interested in the path of this length that maximizes the sum of matrix elements it passes by (for the example input I provided, the path of length 9 is: (start: element (0, 0)) 1, 6, 7, 9, 5, 5, 4, 9, 0 (end: element (n, n)), the sum of which is 46). Breaking the problem down into smaller subproblems does not seem trivial to me, since the final solution for path length of x may be completely different from the final solution for path length of x-1 and thus not composed of the solutions for shorter paths.
            $endgroup$
            – SquaricAcid
            2 hours ago















          0












          $begingroup$

          This is pretty easily solvable in O(n^2). Notice that any longest path from a to c with length >1 is a combination of a longest ab path and a longest bc path for some b. What you want to do here is to find the longest path to all squares using dynamic programming.






          share|improve this answer









          $endgroup$












          • $begingroup$
            The desired path length is given as input, we're interested in the path of this length that maximizes the sum of matrix elements it passes by (for the example input I provided, the path of length 9 is: (start: element (0, 0)) 1, 6, 7, 9, 5, 5, 4, 9, 0 (end: element (n, n)), the sum of which is 46). Breaking the problem down into smaller subproblems does not seem trivial to me, since the final solution for path length of x may be completely different from the final solution for path length of x-1 and thus not composed of the solutions for shorter paths.
            $endgroup$
            – SquaricAcid
            2 hours ago













          0












          0








          0





          $begingroup$

          This is pretty easily solvable in O(n^2). Notice that any longest path from a to c with length >1 is a combination of a longest ab path and a longest bc path for some b. What you want to do here is to find the longest path to all squares using dynamic programming.






          share|improve this answer









          $endgroup$



          This is pretty easily solvable in O(n^2). Notice that any longest path from a to c with length >1 is a combination of a longest ab path and a longest bc path for some b. What you want to do here is to find the longest path to all squares using dynamic programming.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered 11 hours ago









          Oscar SmithOscar Smith

          2,9311123




          2,9311123











          • $begingroup$
            The desired path length is given as input, we're interested in the path of this length that maximizes the sum of matrix elements it passes by (for the example input I provided, the path of length 9 is: (start: element (0, 0)) 1, 6, 7, 9, 5, 5, 4, 9, 0 (end: element (n, n)), the sum of which is 46). Breaking the problem down into smaller subproblems does not seem trivial to me, since the final solution for path length of x may be completely different from the final solution for path length of x-1 and thus not composed of the solutions for shorter paths.
            $endgroup$
            – SquaricAcid
            2 hours ago
















          • $begingroup$
            The desired path length is given as input, we're interested in the path of this length that maximizes the sum of matrix elements it passes by (for the example input I provided, the path of length 9 is: (start: element (0, 0)) 1, 6, 7, 9, 5, 5, 4, 9, 0 (end: element (n, n)), the sum of which is 46). Breaking the problem down into smaller subproblems does not seem trivial to me, since the final solution for path length of x may be completely different from the final solution for path length of x-1 and thus not composed of the solutions for shorter paths.
            $endgroup$
            – SquaricAcid
            2 hours ago















          $begingroup$
          The desired path length is given as input, we're interested in the path of this length that maximizes the sum of matrix elements it passes by (for the example input I provided, the path of length 9 is: (start: element (0, 0)) 1, 6, 7, 9, 5, 5, 4, 9, 0 (end: element (n, n)), the sum of which is 46). Breaking the problem down into smaller subproblems does not seem trivial to me, since the final solution for path length of x may be completely different from the final solution for path length of x-1 and thus not composed of the solutions for shorter paths.
          $endgroup$
          – SquaricAcid
          2 hours ago




          $begingroup$
          The desired path length is given as input, we're interested in the path of this length that maximizes the sum of matrix elements it passes by (for the example input I provided, the path of length 9 is: (start: element (0, 0)) 1, 6, 7, 9, 5, 5, 4, 9, 0 (end: element (n, n)), the sum of which is 46). Breaking the problem down into smaller subproblems does not seem trivial to me, since the final solution for path length of x may be completely different from the final solution for path length of x-1 and thus not composed of the solutions for shorter paths.
          $endgroup$
          – SquaricAcid
          2 hours ago










          SquaricAcid is a new contributor. Be nice, and check out our Code of Conduct.









          draft saved

          draft discarded


















          SquaricAcid is a new contributor. Be nice, and check out our Code of Conduct.












          SquaricAcid is a new contributor. Be nice, and check out our Code of Conduct.











          SquaricAcid is a new contributor. Be nice, and check out our Code of Conduct.














          Thanks for contributing an answer to Code Review Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          Use MathJax to format equations. MathJax reference.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f216717%2fmaximize-path-value%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          कुँवर स्रोत दिक्चालन सूची"कुँवर""राणा कुँवरके वंशावली"

          शेव्रोले वोल्ट अनुक्रम इतिहास इन्हे भी देखें चित्र दीर्घा संदर्भ दिक्चालन सूची

          चैत्य भूमि चित्र दीर्घा सन्दर्भ बाहरी कडियाँ दिक्चालन सूची"Chaitya Bhoomi""Chaitya Bhoomi: Statue of Equality in India""Dadar Chaitya Bhoomi: Statue of Equality in India""Ambedkar memorial: Centre okays transfer of Indu Mill land"चैत्यभमि