题目

传送门

文本

给你一个整数数组 nums ,和一个表示限制的整数 limit,请你返回最长连续子数组的长度,该子数组中的任意两个元素之间的绝对差必须小于或者等于 limit 。

如果不存在满足条件的子数组,则返回 0 。

示例 1:

输入:nums = [8,2,4,7], limit = 4

输出:2

解释:所有子数组如下:

[8] 最大绝对差 |8-8| = 0 <= 4.

[8,2] 最大绝对差 |8-2| = 6 > 4.

[8,2,4] 最大绝对差 |8-2| = 6 > 4.

[8,2,4,7] 最大绝对差 |8-2| = 6 > 4.

[2] 最大绝对差 |2-2| = 0 <= 4.

[2,4] 最大绝对差 |2-4| = 2 <= 4.

[2,4,7] 最大绝对差 |2-7| = 5 > 4.

[4] 最大绝对差 |4-4| = 0 <= 4.

[4,7] 最大绝对差 |4-7| = 3 <= 4.

[7] 最大绝对差 |7-7| = 0 <= 4.

因此,满足题意的最长子数组的长度为 2 。

示例 2:

输入:nums = [10,1,2,4,7,2], limit = 5

输出:4

解释:满足题意的最长子数组是 [2,4,7,2],其最大绝对差 |2-7| = 5 <= 5 。

示例 3:

输入:nums = [4,2,2,2,4,4,2,2], limit = 0

输出:3

提示:

1 <= nums.length <= 10^5
1 <= nums[i] <= 10^9
0 <= limit <= 10^9

来源:力扣(LeetCode)

模板

int longestSubarray(int* nums, int numsSize, int limit){

}

解题

分析

由题意可知:

我们需要分析给的数组的连续子数组的绝对差(数组内最大的元素减去最小的元素得到的值)与所给的Limit进行比较,返回最长的连续且满足绝对差<=limit的子数组的长度

所以理解流程:

首先选取子数组

然后获取绝对差

再比较limit

最后选取下一子数组

然后加上我所能想到的优化

对于已经比较过的符合条件的长度再后面就无需再做比较

最新文章

  1. .Net Globalization and Localization
  2. linux i2c 设备节点读写
  3. 6 高级IO函数
  4. web2.0、互联网+、IT时代与DT时代、工业4.0 引发的思考
  5. Rabbitmq init terminating in do boot 问题
  6. poj 3414 Pots (bfs+线索)
  7. 【RAC】RAC相关基础知识
  8. 7.通用程序设计_EJ
  9. 接口测试,获取登录后的cookies
  10. InnoDB引擎体系架构
  11. 产品半夜发现bug让程序员加班,程序员应如何回应?
  12. oracle的loop等循环语句的几个用法小例子[转]
  13. vim按下ctrl+s僵死
  14. JavaWeb中监听器
  15. 【luogu P3378 堆】 模板
  16. Facebook支持python的开源预测工具Prophet
  17. 每天一个Linux命令(40)vmstat命令
  18. cms-最近更新
  19. C#中流写入类StreamWriter的介绍
  20. PKU_campus_2017_K Lying Island

热门文章

  1. SSH入门开发(实现一个简单的登录功能)详解
  2. TDH社区版搭建总结
  3. Hyperbase数据迁移
  4. hdu3341Lost's revenge (AC自动机+变进制dp)
  5. 国产smartbits版本-minismb测试高恪路由器IP限速
  6. 实战交付一套dubbo微服务到k8s集群(6)之交付dubbo-monitor到K8S集群
  7. kubernetes进阶(一) kubectl工具使用详解
  8. Windows10电脑优化和使用
  9. POJ - 3280 Cheapest Palindrome 【区间dp】【非原创】
  10. anaconda jupyter notebook 启动方法