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

Leetcode每日一练--44

3350. 检测相邻递增子数组 II

难度:中等

提示

给你一个由 n 个整数组成的数组 nums ,请你找出 k 的 最大值,使得存在 两个 相邻 且长度为 k 的 严格递增 子数组。具体来说,需要检查是否存在从下标 a 和 b (a < b) 开始的 两个 子数组,并满足下述全部条件:

  • 这两个子数组 nums[a..a + k - 1] 和 nums[b..b + k - 1] 都是 严格递增 的。
  • 这两个子数组必须是 相邻的,即 b = a + k

返回 k 的 最大可能 值。

子数组 是数组中的一个连续 非空 的元素序列。

示例 1:

输入:nums = [2,5,7,8,9,2,3,4,3,1]

输出:3

解释:

  • 从下标 2 开始的子数组是 [7, 8, 9],它是严格递增的。
  • 从下标 5 开始的子数组是 [2, 3, 4],它也是严格递增的。
  • 这两个子数组是相邻的,因此 3 是满足题目条件的 最大 k 值。

示例 2:

输入:nums = [1,2,3,4,4,4,4,5,6,7]

输出:2

解释:

  • 从下标 0 开始的子数组是 [1, 2],它是严格递增的。
  • 从下标 2 开始的子数组是 [3, 4],它也是严格递增的。
  • 这两个子数组是相邻的,因此 2 是满足题目条件的 最大 k 值。

提示:

  • 2 <= nums.length <= 2 * 10^5
  • -109 <= nums[i] <= 10^9

代码

int maxIncreasingSubarrays(int* nums, int numsSize) {// 预处理左侧递增序列长度:left_inc[i]表示以i结尾的连续递增长度int* left_inc = (int*)malloc(numsSize * sizeof(int));left_inc[0] = 1;for (int i = 1; i < numsSize; i++) {if (nums[i] > nums[i - 1]) {left_inc[i] = left_inc[i - 1] + 1;} else {left_inc[i] = 1;}}// 预处理右侧递增序列长度:right_inc[i]表示从i开始的最长连续递增长度int* right_inc = (int*)malloc(numsSize * sizeof(int));right_inc[numsSize - 1] = 1;for (int i = numsSize - 2; i >= 0; i--) {if (nums[i] < nums[i + 1]) {right_inc[i] = right_inc[i + 1] + 1;} else {right_inc[i] = 1;}}int ans = 0;// 遍历所有可能的分界点(第一个子数组的结束位置)for (int i = 0; i < numsSize - 1; i++) {int k_candidate = left_inc[i] < right_inc[i + 1] ? left_inc[i] : right_inc[i + 1];if (k_candidate > ans) {ans = k_candidate;}}free(left_inc);free(right_inc);return ans;
}

http://www.dtcms.com/a/540505.html

相关文章:

  • Leetcode 3728. Stable Subarrays With Equal Boundary and Interior Sum
  • 江科大stm32 | OLED显示汉字
  • vue3前端解析excel文件
  • 5.1.5 大数据方法论与实践指南-数据仓库存储格式选择
  • 网站空间1g多少钱怎么做网站加盟
  • 学校网站怎么做推广上海网站建站多少钱
  • php网站开发心得体会漯河市网站建设
  • 打工人日报#20251028
  • 手写前端脚手架cli
  • 《内蒙古自治区本级政务信息化运行维护项目预算支出方案编制规范和预算支出标准(试行)》(内财预〔2024〕194号)标准解读
  • 在 Spring Boot 项目中使用分页插件的两种常见方式
  • MapReduce运行实例
  • “透彻式学习”与“渗透式学习”
  • 惠洋科技H5528K 100V高耐压2.5A 支持24V30V36V48V60V72V80V降压6V9V12V车灯供电恒流芯片IC 高低亮
  • Spring Boot3零基础教程,Actuator 导入,笔记82
  • 如何用PyQt5实现一个简易计算器应用
  • Spring Boot 事务管理深度解析
  • 【系统分析师】高分论文:软件的系统测试及应用(电子商务门户网站系统)
  • 尚硅谷React扩展笔记
  • 8.模板和string(下)
  • 5G专网客户案例分享:基于可编程5G的工业互联网产线验证系统
  • 前端:前端开发中,实现水印(Watermark)
  • 网站排名方法胶州网站建设 网络推广
  • 潍坊商城网站建设修改wordpress样式
  • AI智能体从系统智能到生态智能:SmartMediaKit 如何成为智能体时代的视频神经系统
  • 【音视频】H.264关键帧识别
  • AI智能相机未来应用
  • grafana做状态变化的监控图表
  • 19.高级的ACL
  • 网站推广广告营销方案海南省建设培训网站报名