最大点数与成本

2024-08-18 0 534

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

难度:中等

主题: 数组、动态规划

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

要获得积分,您必须在每一行中选择一个单元格。选择坐标 (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。最大积分与费用

1

2

3

4

5

6

<?php // Example usage:

$points1 = [[1, 5], [2, 3], [4, 2]];

$points2 = [[2, 4, 3], [5, 6, 4]];

echo maxPoints($points1); // Output: 11

echo maxPoints($points2); // Output: 9

?>

解释:

  • 左数组和右数组: 这些帮助我们通过考虑前一行的值来计算每个单元格可以获得的最大分数,有效地考虑跨列移动的惩罚。
  • 动态编程方法: 此方法确保每一行都是基于前一行计算的,使得解决方案可针对大型矩阵进行扩展。

这种方法的时间复杂度为 (o(m times n)),在给定约束的情况下是有效的。

联系链接

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

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

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

  • 领英
  • github
收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

免责声明
1. 本站所有资源来源于用户上传和网络等,如有侵权请邮件联系本站整改team@lcwl.fun!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系本站工作人员处理!
6. 本站资源售价或VIP只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 因人力时间成本问题,部分源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别!
9.本站所有源码资源都是经过本站工作人员人工亲测可搭建的,保证每个源码都可以正常搭建,但不保证源码内功能都完全可用,源码属于可复制的产品,无任何理由退款!

网站搭建学习网 PHP 最大点数与成本 https://www.xuezuoweb.com/13886.html

常见问题
  • 本站所有的源码都是经过平台人工部署搭建测试过可用的
查看详情
  • 购买源码资源时购买了带主机的套餐是指可以享受源码和所选套餐型号的主机两个产品,在本站套餐里开通主机可享优惠,最高免费使用主机
查看详情

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务

Fa快捷助手
手机编程软件开发

在手机上用手点一点就能轻松做软件

去做软件
链未云主机
免备案香港云主机

开通主机就送域名的免备案香港云主机

去使用
链未云服务器
免备案香港云服务器

支持售后、超低价、稳定的免备案香港云服务器

去使用