赞
踩
难点:保存数组缩小后的最大最小值
class Solution { public: int longestSubarray(vector<int>& nums, int limit) { deque<int> quemax,quemin; int n = nums.size(),res=0; for(int i=0,j=0;i<n;i++) { while(!quemax.empty() && quemax.back() < nums[i]) quemax.pop_back(); while(!quemin.empty() && quemin.back() > nums[i]) quemin.pop_back(); quemax.push_back(nums[i]); quemin.push_back(nums[i]); while(!quemax.empty() && !quemin.empty() && quemax.front() - quemin.front() > limit) { if(quemax.front() == nums[j]) quemax.pop_front(); if(quemin.front() == nums[j]) quemin.pop_front(); j ++; } res = max(res,i-j+1); } return res; } };
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。