搜索
首页后端开发php教程两个最好的不重叠事件

两个最好的不重叠事件

Dec 11, 2024 pm 03:01 PM

2054。两个最好的不重叠的事件

难度:中等

主题:数组、二分查找、动态规划、排序、堆(优先级队列)

您将获得一个 0 索引 2D 事件整数数组,其中 events[i] = [startTimei, endTimei, value]。第i活动从startTimei开始,到endTimei结束,如果您参加本次活动,您将获得价值valuei 。您可以选择最多两个不重叠的活动参加,以使它们的值之和最大化

返回此最大总和。

请注意,开始时间和结束时间包含:也就是说,您不能参加两个活动,其中一个活动同时开始,另一个活动同时结束。更具体地说,如果您参加结束时间为 t 的活动,则下一个活动必须在 t 1 或之后开始。

示例1:

Two Best Non-Overlapping Events

  • 输入: events = [[1,3,2],[4,5,2],[2,4,3]]
  • 输出: 4
  • 解释: 选择绿色事件 0 和 1,总和为 2 2 = 4。

示例2:

Two Best Non-Overlapping Events

  • 输入: events = [[1,3,2],[4,5,2],[1,5,5]]
  • 输出: 5
  • 解释:选择事件 2,总和为 5。

示例 3:

Two Best Non-Overlapping Events

  • 输入: events = [[1,5,3],[1,5,1],[6,6,5]]
  • 输出: 8
  • 解释: 选择事件 0 和 2,总和为 3 5 = 8。

约束:

  • 2 5
  • 事件[i].length == 3
  • 1 i i 9
  • 1 i 6

提示:

  1. 根据事件的开始时间对事件进行排序有何帮助?结束时间怎么样?
  2. 如何快速得到与我们选择的区间不相交的区间的最高分?

解决方案:

我们可以使用以下方法:

方法

  1. 按结束时间对活动进行排序:

    • 排序帮助我们使用二分搜索有效地找到不重叠的事件。
  2. 非重叠事件的二分搜索:

    • 使用二分搜索查找在当前事件开始时间之前结束的最新事件。这确保了不重叠。
  3. 使用最大跟踪的动态规划:

    • 在迭代排序的事件时,维护事件的最大值直到当前事件。这使我们能够快速计算两个事件的最大总和。
  4. 迭代并计算最大和:

    • 对于每个事件,使用以下方法计算可能的总和:
      • 仅限当前活动。
      • 当前事件与使用二分搜索找到的最佳非重叠事件相结合。

让我们用 PHP 实现这个解决方案:2054。两个最佳不重叠事件

<?php /**
 * @param Integer[][] $events
 * @return Integer
 */
function maxTwoEvents($events) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example Usage:
$events1 = [[1, 3, 2], [4, 5, 2], [2, 4, 3]];
$events2 = [[1, 3, 2], [4, 5, 2], [1, 5, 5]];
$events3 = [[1, 5, 3], [1, 5, 1], [6, 6, 5]];

echo maxTwoEvents($events1) . "\n"; // Output: 4
echo maxTwoEvents($events2) . "\n"; // Output: 5
echo maxTwoEvents($events3) . "\n"; // Output: 8
?>

解释:

  1. 排序

    • 事件按结束时间排序,这样可以有效搜索最后一个不重叠的事件。
  2. 二分查找:

    • 对于每个事件,二分搜索确定当前事件开始之前结束的最新事件。
  3. 最大追踪:

    • 我们维护一个数组 maxUpTo,它存储直到当前索引的事件的最大值。这可以避免重新计算早期索引的最大值。
  4. 最大和计算:

    • 对于每个事件,计算其值与最佳非重叠事件值的总和。相应地更新全局最大总和。

复杂性分析

  • 排序O(n log n)
  • 对每个事件进行二分搜索O(log n),重复n次→ O(n log n)
  • 总体O(n log n)

这个解决方案非常高效,并且在限制范围内运行良好。

联系链接

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

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

  • 领英
  • GitHub

以上是两个最好的不重叠事件的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
绝对会话超时有什么区别?绝对会话超时有什么区别?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。

为会话cookie设置httponly标志的重要性是什么?为会话cookie设置httponly标志的重要性是什么?May 03, 2025 am 12:10 AM

设置httponly标志对会话cookie至关重要,因为它能有效防止XSS攻击,保护用户会话信息。具体来说,1)httponly标志阻止JavaScript访问cookie,2)在PHP和Flask中可以通过setcookie和make_response设置该标志,3)尽管不能防范所有攻击,但应作为整体安全策略的一部分。

PHP会议在网络开发中解决了什么问题?PHP会议在网络开发中解决了什么问题?May 03, 2025 am 12:02 AM

phpsessions solvathepromblymaintainingStateAcrossMultipleHttpRequestsbyStoringDataTaNthEserVerAndAssociatingItwithaIniquesestionId.1)他们储存了AtoredAtaserver side,通常是Infilesordatabases,InseasessessionIdStoreDistordStoredStoredStoredStoredStoredStoredStoreDoreToreTeReTrestaa.2)

可以在PHP会话中存储哪些数据?可以在PHP会话中存储哪些数据?May 02, 2025 am 12:17 AM

phpsessionscanStorestrings,数字,数组和原始物。

您如何开始PHP会话?您如何开始PHP会话?May 02, 2025 am 12:16 AM

tostartaphpsession,usesesses_start()attheScript'Sbeginning.1)placeitbeforeanyOutputtosetThesessionCookie.2)useSessionsforuserDatalikeloginstatusorshoppingcarts.3)regenerateSessiveIdStopreventFentfixationAttacks.s.4)考虑使用AttActAcks.s.s.4)

什么是会话再生,如何提高安全性?什么是会话再生,如何提高安全性?May 02, 2025 am 12:15 AM

会话再生是指在用户进行敏感操作时生成新会话ID并使旧ID失效,以防会话固定攻击。实现步骤包括:1.检测敏感操作,2.生成新会话ID,3.销毁旧会话ID,4.更新用户端会话信息。

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

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

热工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)