0

0

优化2xN网格最大路径和的动态规划实现

碧海醫心

碧海醫心

发布时间:2025-11-25 09:22:02

|

736人浏览过

|

来源于php中文网

原创

优化2xN网格最大路径和的动态规划实现

本文详细探讨了如何在2xn网格中,从a[0]到b[n-1]寻找最大路径和的动态规划方法。我们将分析一种常见的dp实现,并提出关键优化点,包括减少重复计算和合并循环结构,以提升代码的简洁性和执行效率,同时保持算法的时间复杂度为o(n)。

问题描述

在一个2xN的网格中,给定两个一维整数数组A和B,长度均为N。我们的目标是从网格的起始点A[0](对应网格坐标(0,0))移动到终点B[N-1](对应网格坐标(1,N-1)),每次移动只能向右或向下。在移动过程中,路径上的所有元素之和需要最大化。

动态规划思路

解决此类路径规划问题,动态规划(DP)是一种高效且常用的方法。我们定义一个dp表来存储到达每个位置的最大路径和。由于网格是2xN,我们可以使用一个2xN的dp数组,其中dp[row][col]表示从A[0]到达网格位置(row, col)的最大路径和。

状态定义:

  • dp[0][i]:表示从A[0]到达A[i](即网格位置(0, i))的最大路径和。
  • dp[1][i]:表示从A[0]到达B[i](即网格位置(1, i))的最大路径和。

基本情况 (Base Cases):

  • dp[0][0] = A[0]:从A[0]到达A[0]的路径和就是A[0]本身。
  • dp[1][0] = dp[0][0] + B[0]:从A[0]到达B[0]的唯一方式是先到A[0],然后向下移动到B[0]。

状态转移方程 (Transition Equations):

  • 对于第一行(数组A),当i > 0时: dp[0][i] = dp[0][i-1] + A[i] 因为在第一行,只能从左侧的A[i-1]向右移动到A[i]。
  • 对于第二行(数组B),当i > 0时: dp[1][i] = max(dp[1][i-1] + B[i], dp[0][i] + B[i]) 到达B[i]有两种可能的路径:
    1. 从B[i-1]向右移动到B[i]。
    2. 从A[i]向下移动到B[i]。 我们选择这两种路径中和最大的一个。

最终结果即为dp[1][N-1]。

炉米Lumi
炉米Lumi

字节跳动推出的AI模型分享社区和模型训练平台

下载

初始实现分析

以下是一个基于上述动态规划思路的Python实现示例:

def max_path_sum_initial(A, B):
    N = len(A)
    dp = [[0 for _ in range(N)] for _ in range(2)]

    # 初始化 A[0]
    dp[0][0] = A[0]

    # 计算第一行的最大路径和
    for i in range(1, N):
        dp[0][i] = dp[0][i - 1] + A[i]

    # 原始代码中可能存在的重复计算或不当初始化
    # dp[1][0] = dp[0][0] + B[0] # 如果这行在第二个循环内,则会重复计算

    # 计算第二行的最大路径和
    for i in range(1, N):
        # 假设 dp[1][0] 已经正确初始化
        dp[1][i] = max(dp[1][i - 1] + B[i], dp[0][i] + B[i])

    # 注意:原始代码中 dp[1][0] 的初始化可能被放置在第二个循环之前或内部,
    # 从而导致重复计算或逻辑不清晰。
    return dp[1][N - 1]

在上述初始实现中,存在两个可以优化的点:

  1. dp[1][0]的重复计算: 如果dp[1][0] = dp[0][0] + B[0]这行代码被不当地放置在第二个循环内部,它将在每次迭代中被重复计算。dp[1][0]的值仅依赖于dp[0][0]和B[0],这些值在循环开始前就已确定。因此,它应该只计算一次。
  2. 循环结构: 计算dp[0][i]和dp[1][i]的两个循环是独立的。然而,dp[1][i]的计算只依赖于dp[1][i-1]和dp[0][i]。由于dp[0][i]在计算dp[1][i]之前就已经确定,这两个循环可以合并为一个,从而提高代码的紧凑性和可读性。

优化实现

根据上述分析,我们可以对实现进行优化。核心思想是将dp[1][0]的初始化移到循环之外,并合并两个独立的循环。

def max_path_sum_optimized(A, B):
    N = len(A)
    # 处理空输入情况
    if N == 0:
        return 0 

    # 初始化一个2xN的dp表
    # dp[0] 对应数组 A, dp[1] 对应数组 B
    dp = [[0 for _ in range(N)] for _ in range(2)]

    # 基本情况:初始化起始点 A[0]
    dp[0][0] = A[0]
    # 基本情况:初始化 B[0]。从 A[0] 向下移动到 B[0]
    dp[1][0] = dp[0][0] + B[0]

    # 合并循环,同时计算第一行和第二行的后续状态
    for i in range(1, N):
        # 计算到达 A[i] 的最大路径和 (只能从 A[i-1] 向右移动)
        dp[0][i] = dp[0][i - 1] + A[i]

        # 计算到达 B[i] 的最大路径和
        # 两种路径:
        # 1. 从左侧 B[i-1] 向右移动到 B[i]
        # 2. 从上方 A[i] 向下移动到 B[i]
        dp[1][i] = max(dp[1][i - 1] + B[i], dp[0][i] + B[i])

    # 最终结果是到达 B[N-1] 的最大路径和
    return dp[1][N - 1]

优化说明:

  • dp[1][0]的提前计算: dp[1][0]的值仅依赖于dp[0][0]和B[0],这些值在循环开始前就已确定。将其计算移出循环,避免了不必要的重复操作,使代码逻辑更清晰。
  • 循环合并: dp[0][i]和dp[1][i]的计算可以在同一个for循环中完成。这是因为dp[1][i]只依赖于dp[1][i-1]和`dp[0][i

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

760

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

639

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

762

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

618

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1265

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 3.7万人学习

Django 教程
Django 教程

共28课时 | 3.2万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号