当前位置: 首页 > news >正文

leetcode 每日一题 3439. 重新安排会议得到最多空余时间 I

3439. 重新安排会议得到最多空余时间 I

给你一个整数 eventTime 表示一个活动的总时长,这个活动开始于 t = 0 ,结束于 t = eventTime 。
同时给你两个长度为 n 的整数数组 startTime 和 endTime 。它们表示这次活动中 n 个时间 没有重叠 的会议,其中第 i 个会议的时间为 [startTime[i], endTime[i]] 。
你可以重新安排 至多 k 个会议,安排的规则是将会议时间平移,且保持原来的 会议时长 ,你的目的是移动会议后 最大化 相邻两个会议之间的 最长 连续空余时间。
移动前后所有会议之间的 相对 顺序需要保持不变,而且会议时间也需要保持互不重叠。
请你返回重新安排会议以后,可以得到的 最大 空余时间。
注意,会议 不能 安排到整个活动的时间以外。
示例 1:
输入: eventTime = 5, k = 1, startTime = [1,3], endTime = [2,5]
输出: 2
解释:

将 [1, 2] 的会议安排到 [2, 3] ,得到空余时间 [0, 2] 。
示例 2:
输入: eventTime = 10, k = 1, startTime = [0,2,9], endTime = [1,4,10]
输出: 6
解释:

将 [2, 4] 的会议安排到 [1, 3] ,得到空余时间 [3, 9] 。
示例 3:
输入: eventTime = 5, k = 2, startTime = [0,1,2,3,4], endTime = [1,2,3,4,5]
输出: 0
解释:
活动中的所有时间都被会议安排满了。
提示:

  • 1 <= eventTime <= 109
  • n == startTime.length == endTime.length
  • 2 <= n <= 105
  • 1 <= k <= n
  • 0 <= startTime[i] < endTime[i] <= eventTime
  • endTime[i] <= startTime[i + 1] 其中 i 在范围 [0, n - 2] 之间。

思路

添加一个(0,0)(开始,结束)的活动和(eventTime,eventTime)的活动,处理边界情况
安排连续的k个活动,使间隔时间最大。例如有时长别是1,2,3,4,5,6的活动,k=3,可以安排3,4,5,使2,6的时间间隔最大。最大间隔时长即 【6开始的时间-2结束的时间-3,4,5持续的时间】 。枚举所有这种的情况即可。

func maxFreeTime(eventTime int, k int, startTime []int, endTime []int) int {  startTime = slices.Insert(startTime, 0, 0)  endTime = slices.Insert(endTime, 0, 0)  startTime = append(startTime, eventTime)  endTime = append(endTime, eventTime)  // fmt.Println(startTime, endTime)  lens := []int{}  for i := 0; i < len(startTime); i++ {  lens = append(lens, endTime[i]-startTime[i])  }  prevSum := []int{lens[0]}  for i := 1; i < len(lens); i++ {  prevSum = append(prevSum, prevSum[i-1]+lens[i])  }  if len(startTime) <= k+1 {  return eventTime - prevSum[len(prevSum)-1]  }  ans := 0  for i := 0; i < len(startTime)-k-1; i++ {  ans = max(ans, startTime[i+k+1]-endTime[i]-(prevSum[i+k]-prevSum[i]))  }  return ans  
}
http://www.dtcms.com/a/270912.html

相关文章:

  • 二刷 黑马点评 部署
  • 大模型MoE模型技术详解
  • 专题一_双指针_查找总价格为目标值的两个商品
  • 小程序主体变更全攻略:流程、资料与异常处理方案
  • WPF学习笔记(27)科学计算器
  • 李宏毅NLP-9-语音转换
  • 无人机报警器频段模块设计与运行要点
  • 小米路由器3C刷OpenWrt,更换系统/变砖恢复 指南
  • 在 Spring Boot 中如何使用 Assert 进行断言校验
  • 安卓设备信息查看器 - 功能介绍
  • 【bug修复积累】关于包装类型和基本数据类型的使用
  • 在Ubuntu上安装配置 LLaMA-Factory
  • Go 延迟调用 defer 用法详解
  • vscode 防止linux索引爆红
  • SQL Server通过存储过程实现HTML页面生成
  • Python爬取闲鱼价格趋势并可视化分析
  • Using Spring for Apache Pulsar:Message Production
  • 基于svga+uniapp的微信小程序动画组件开发指南
  • pytorch的详细安装教程
  • 百度文心一言开源ERNIE-4.5深度测评报告:技术架构解读与性能对比
  • “AI 曼哈顿计划”:科技竞赛还是人类挑战?
  • AI识别 + 食品质量安全预警系统
  • 18-C#改变形参内容
  • 工程改Mvvm
  • Java零基础笔记09(Java编程核心:面向对象编程高级练习:支付模块)
  • 自动化运维工程师实操面试题
  • Jenkins 流水线配置
  • SQLite密码修改故障排查:RSA加密随机性导致的数据库匹配问题
  • ABAP 调用 ZCL_EXCEL_READER_2007举例
  • 虚幻引擎5 GAS开发俯视角RPG游戏 #5-8:倾听属性变化