0

0

最大点数与成本

WBOY

WBOY

发布时间:2024-08-18 09:09:20

|

1119人浏览过

|

来源于dev.to

转载

1937 年。最大积分数量与成本

难度:中等

主题: 数组、动态规划

给你一个 m x n 整数矩阵点(0 索引)。从 0 点开始,您希望最大化可以从矩阵中获得的点数。

magento(麦进斗)
magento(麦进斗)

Magento是一套专业开源的PHP电子商务系统。Magento设计得非常灵活,具有模块化架构体系和丰富的功能。易于与第三方应用系统无缝集成。Magento开源网店系统的特点主要分以下几大类,网站管理促销和工具国际化支持SEO搜索引擎优化结账方式运输快递支付方式客户服务用户帐户目录管理目录浏览产品展示分析和报表Magento 1.6 主要包含以下新特性:•持久性购物 - 为不同的

下载

要获得积分,您必须在每一行中选择一个单元格。选择坐标 (r, c) 处的单元格将为您的分数添加 分 [r][c]。

但是,如果您选择的单元格距离您在上一行中选择的单元格太远,您将失去分数。对于每两个相邻行 r 和 r + 1(其中 0 1) 和 (r + 1, c2) 处选取单元格将减去 abs (c1 - c2) 来自您的分数。返回

您能获得的最大积分

abs(x) 定义为:

    x 为 x >= 0.
  • -x 代表 x

示例1:

最大点数与成本

  • 输入: l1 = [2,4,3], l2 = [5,6,4]
  • 输出: 9
  • 说明:
      蓝色单元格表示要选取的最佳单元格,其坐标为 (0, 2)、(1, 1) 和 (2, 0)。
    • 您将 3 + 5 + 3 = 11 加到您的分数上。
    • 但是,你必须从你的分数中减去abs(2 - 1) + abs(1 - 0) = 2。
    • 您的最终得分是 11 - 2 = 9.

示例2:

最大点数与成本

  • 输入: 点 = [[1,5],[2,3],[4,2]]
  • 输出: 11
  • 说明:
      蓝色单元格表示要选取的最佳单元格,其坐标为 (0, 1)、(1, 1) 和 (2, 0)。
    • 您将 5 + 3 + 4 = 12 加到您的分数上。
    • 但是,你必须从你的分数中减去abs(1 - 1) + abs(1 - 0) = 1。
    • 您的最终得分是 12 - 1 = 11。

限制:

    m == 点.长度
  • n == 点[r].长度
  • 1 51 50 5

提示:

    尝试使用动态规划。
  1. dp[i][j] 是如果点[i][j] 是您最近选择的单元格时您可以拥有的最大点数。

解决方案:

我们可以将解决方案分解为几个步骤:

第 1 步:定义 dp 数组

我们将使用 2d 数组 dp,其中 dp[i][j] 表示通过选择第 i 行和 j 列的单元格可以获得的最大点数。

步骤2:初始化dp阵列

初始化第一行 dp 与第一行点相同,因为没有前面的行可以减去成本。

步骤 3:计算每行的 dp 值

对于每个后续行,我们考虑到从前一行切换的成本来计算每列的最大可能点。

为了高效计算从第 i-1 行到第 i 行的转换,我们可以使用左右两个辅助数组:

    left[j] 将存储我们可以为第 j 列实现的最大值,仅考虑从左侧的转换。
  • right[j] 将存储我们可以为第 j 列实现的最大值,仅考虑从右侧的转换。
步骤 4:更新每行的 dp

对于第 i 行中的每一列 j:

    使用 left[j] 或 right[j] 中的最大值加上点 [i][j] 来更新 dp[i][j]。
步骤 5:返回最后一行的最大值

结果将是 dp 数组最后一行的最大值。

让我们用 php 实现这个解决方案:

1937。最大积分与费用


解释:

  • 左数组和右数组: 这些帮助我们通过考虑前一行的值来计算每个单元格可以获得的最大分数,有效地考虑跨列移动的惩罚。
  • 动态编程方法: 此方法确保每一行都是基于前一行计算的,使得解决方案可针对大型矩阵进行扩展。
这种方法的时间复杂度为 (o(m times n)),在给定约束的情况下是有效的。

联系链接

如果您发现本系列有帮助,请考虑在 github 上给

存储库 一颗星,或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

如果您想要更多类似的有用内容,请随时关注我:

  • 领英
  • github

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2687

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1662

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1522

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

953

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1420

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1488

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.8万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

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

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