搜索
首页后端开发php教程。重叠子数组的最大和

. Maximum Sum of on-Overlapping Subarrays

689。 3 个不重叠子数组的最大和

难度:

主题:数组,动态规划

给定一个整数数组 nums 和一个整数 k,找到三个长度为 k 且总和最大的不重叠子数组并返回它们。

返回结果作为表示每个间隔起始位置的索引列表(0-索引。如果有多个答案,则返回字典顺序最小的一个

示例1:

  • 输入: nums = [1,2,1,2,6,7,5,1], k = 2
  • 输出: [0,3,5]
  • 解释: 子数组 [1, 2], [2, 6], [7, 5] 对应于起始索引 [0, 3, 5]。
    • 我们也可以采用 [2, 1],但是 [1, 3, 5] 的答案按字典顺序会更大。

示例2:

  • 输入: nums = [1,2,1,2,1,2,1,2,1], k = 2
  • 输出: [0,2,4]

约束:

  • 1 4
  • 1 16
  • 1

解决方案:

我们将使用动态规划方法。这个想法是将问题分解为更小的子问题,利用子数组的重叠来有效计算长度为 k 的三个非重叠子数组的最大和。

方法:

  1. 预先计算长度为 k 的子数组的总和:
    首先,我们计算输入数组 nums 中所有长度为 k 的子数组的总和。通过使用滑动窗口技术,可以在线性时间内有效地完成此操作。

  2. 动态规划(DP):
    我们创建两个辅助数组(左数组和右数组)来存储截至当前位置找到的最佳子数组的索引。 left[i] 将存储在索引 i 之前结束的最佳子数组的索引,而 right[i] 将存储在索引 i 之后开始的最佳子数组的索引。

  3. 迭代并计算最大和:
    对于从索引 j 开始的每个可能的中间子数组,我们通过考虑 j 之前的最佳左子数组和 j 之后的最佳右子数组来计算总和。

  4. 字典顺序:
    如果有多个有效答案(总和相同),我们返回字典顺序最小的一个。这是通过迭代顺序来确保的。

让我们用 PHP 实现这个解决方案:689。 3 个不重叠子数组的最大和

<?php /**
 * @param Integer[] $nums
 * @param Integer $k
 * @return Integer[]
 */
function maxSumOfThreeSubarrays($nums, $k) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Test cases
print_r(maxSumOfThreeSubarrays([1,2,1,2,6,7,5,1], 2)); // [0, 3, 5]
print_r(maxSumOfThreeSubarrays([1,2,1,2,1,2,1,2,1], 2)); // [0, 2, 4]
?>

解释:

  1. 子数组和计算:

    • 我们计算长度为 k 的所有可能子数组的总和。这是通过首先计算前 k 个元素的总和来完成的。然后,对于每个后续位置,我们减去留下的元素并添加数组中的下一个元素,使其成为一种有效的滑动窗口方法。
  2. 左右数组:

    • left[i] 保存在索引 i 之前结束且具有最大总和的子数组的索引。
    • right[i] 保存从索引 i 之后开始的具有最大总和的子数组的索引。
  3. 最终计算:

    • 对于每个中间子数组 j,我们检查最佳左子数组和最佳右子数组的组合,如果总和大于当前最大值,则更新结果。
  4. 字典顺序上最小的答案:

    • 当我们从左到右迭代时,我们通过自然地选择产生最大总和的第一个子数组来确保字典顺序最小的解决方案。

例子:

输入:

$nums = [1, 2, 1, 2, 6, 7, 5, 1];
$k = 2;

输出将是:

[0, 3, 5]

这种方法确保了时间复杂度保持高效,时间复杂度约为 O(n),其中 n 是输入数组 nums 的长度。

联系链接

如果您发现本系列有帮助,请考虑在 GitHub 上给 存储库 一个星号或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

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

  • 领英
  • GitHub

以上是。重叠子数组的最大和的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
unset()和session_destroy()有什么区别?unset()和session_destroy()有什么区别?May 04, 2025 am 12:19 AM

Thedifferencebetweenunset()andsession_destroy()isthatunset()clearsspecificsessionvariableswhilekeepingthesessionactive,whereassession_destroy()terminatestheentiresession.1)Useunset()toremovespecificsessionvariableswithoutaffectingthesession'soveralls

在负载平衡的情况下,什么是粘性会话(会话亲和力)?在负载平衡的情况下,什么是粘性会话(会话亲和力)?May 04, 2025 am 12:16 AM

stickysessensureuserRequestSarerOutedTothesMeServerForsessionDataConsisterency.1)sessionIdentificeAssificationAssigeaSsignAssignSignSuserServerServerSustersusiseCookiesorUrlModifications.2)一致的ententRoutingDirectSsssssubsequeSssubsequeSubsequestrequestSameSameserver.3)loadBellankingDisteributesNebutesneNewuserEreNevuseRe.3)

PHP中有哪些不同的会话保存处理程序?PHP中有哪些不同的会话保存处理程序?May 04, 2025 am 12:14 AM

phpoffersvarioussessionsionsavehandlers:1)文件:默认,简单的ButMayBottLeneckonHigh-trafficsites.2)Memcached:高性能,Idealforsforspeed-Criticalapplications.3)REDIS:redis:similartomemememememcached,withddeddeddedpassistence.4)withddeddedpassistence.4)databases:gelifforcontrati forforcontrati,有用

PHP中的会话是什么?为什么使用它们?PHP中的会话是什么?为什么使用它们?May 04, 2025 am 12:12 AM

PHP中的session是用于在服务器端保存用户数据以在多个请求之间保持状态的机制。具体来说,1)session通过session_start()函数启动,并通过$_SESSION超级全局数组存储和读取数据;2)session数据默认存储在服务器的临时文件中,但可通过数据库或内存存储优化;3)使用session可以实现用户登录状态跟踪和购物车管理等功能;4)需要注意session的安全传输和性能优化,以确保应用的安全性和效率。

说明PHP会话的生命周期。说明PHP会话的生命周期。May 04, 2025 am 12:04 AM

PHPsessionsstartwithsession_start(),whichgeneratesauniqueIDandcreatesaserverfile;theypersistacrossrequestsandcanbemanuallyendedwithsession_destroy().1)Sessionsbeginwhensession_start()iscalled,creatingauniqueIDandserverfile.2)Theycontinueasdataisloade

绝对会话超时有什么区别?绝对会话超时有什么区别?May 03, 2025 am 12:21 AM

绝对会话超时从会话创建时开始计时,闲置会话超时则从用户无操作时开始计时。绝对会话超时适用于需要严格控制会话生命周期的场景,如金融应用;闲置会话超时适合希望用户长时间保持会话活跃的应用,如社交媒体。

如果会话在服务器上不起作用,您将采取什么步骤?如果会话在服务器上不起作用,您将采取什么步骤?May 03, 2025 am 12:19 AM

服务器会话失效可以通过以下步骤解决:1.检查服务器配置,确保会话设置正确。2.验证客户端cookies,确认浏览器支持并正确发送。3.检查会话存储服务,如Redis,确保其正常运行。4.审查应用代码,确保会话逻辑正确。通过这些步骤,可以有效诊断和修复会话问题,提升用户体验。

session_start()函数的意义是什么?session_start()函数的意义是什么?May 03, 2025 am 12:18 AM

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。