力扣1438. 绝对差不超过限制的最长连续子数组-C语言实现-中等难度
题目
文本
给你一个整数数组 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
最后选取下一子数组
然后加上我所能想到的优化
对于已经比较过的符合条件的长度再后面就无需再做比较
最新文章
- .Net Globalization and Localization
- linux i2c 设备节点读写
- 6 高级IO函数
- web2.0、互联网+、IT时代与DT时代、工业4.0 引发的思考
- Rabbitmq init terminating in do boot 问题
- poj 3414 Pots (bfs+线索)
- 【RAC】RAC相关基础知识
- 7.通用程序设计_EJ
- 接口测试,获取登录后的cookies
- InnoDB引擎体系架构
- 产品半夜发现bug让程序员加班,程序员应如何回应?
- oracle的loop等循环语句的几个用法小例子[转]
- vim按下ctrl+s僵死
- JavaWeb中监听器
- 【luogu P3378 堆】 模板
- Facebook支持python的开源预测工具Prophet
- 每天一个Linux命令(40)vmstat命令
- cms-最近更新
- C#中流写入类StreamWriter的介绍
- PKU_campus_2017_K Lying Island
热门文章
- SSH入门开发(实现一个简单的登录功能)详解
- TDH社区版搭建总结
- Hyperbase数据迁移
- hdu3341Lost's revenge (AC自动机+变进制dp)
- 国产smartbits版本-minismb测试高恪路由器IP限速
- 实战交付一套dubbo微服务到k8s集群(6)之交付dubbo-monitor到K8S集群
- kubernetes进阶(一) kubectl工具使用详解
- Windows10电脑优化和使用
- POJ - 3280 Cheapest Palindrome 【区间dp】【非原创】
- anaconda jupyter notebook 启动方法