#include <iostream>
#include <vector>
#include <deque>
#include <algorithm>
using namespace std;
int longestSubarray(vector<int>& nums, int limit) {
deque<int> max_d, min_d;
int i = 0, res = 0;
for (int j = 0; j < nums.size(); ++j) {
while (!max_d.empty() && nums[j] > max_d.back()) max_d.pop_back();
while (!min_d.empty() && nums[j] < min_d.back()) min_d.pop_back();
max_d.push_back(nums[j]);
min_d.push_back(nums[j]);
while (max_d.front() - min_d.front() > limit) {
if (max_d.front() == nums[i]) max_d.pop_front();
if (min_d.front() == nums[i]) min_d.pop_front();
i++;
}
res = max(res, j - i + 1);
}
return res;
}
int main() {
vector<int> test = {4, 2, 3, 6, 2, 2, 3, 2, 7};
int limit = 1;
cout << "Longest N-stable: " << longestSubarray(test, limit) << endl; // Output: 4
return 0;
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8dmVjdG9yPgojaW5jbHVkZSA8ZGVxdWU+CiNpbmNsdWRlIDxhbGdvcml0aG0+Cgp1c2luZyBuYW1lc3BhY2Ugc3RkOwoKaW50IGxvbmdlc3RTdWJhcnJheSh2ZWN0b3I8aW50PiYgbnVtcywgaW50IGxpbWl0KSB7CiAgICBkZXF1ZTxpbnQ+IG1heF9kLCBtaW5fZDsKICAgIGludCBpID0gMCwgcmVzID0gMDsKICAgIGZvciAoaW50IGogPSAwOyBqIDwgbnVtcy5zaXplKCk7ICsraikgewogICAgICAgIHdoaWxlICghbWF4X2QuZW1wdHkoKSAmJiBudW1zW2pdID4gbWF4X2QuYmFjaygpKSBtYXhfZC5wb3BfYmFjaygpOwogICAgICAgIHdoaWxlICghbWluX2QuZW1wdHkoKSAmJiBudW1zW2pdIDwgbWluX2QuYmFjaygpKSBtaW5fZC5wb3BfYmFjaygpOwogICAgICAgIG1heF9kLnB1c2hfYmFjayhudW1zW2pdKTsKICAgICAgICBtaW5fZC5wdXNoX2JhY2sobnVtc1tqXSk7CgogICAgICAgIHdoaWxlIChtYXhfZC5mcm9udCgpIC0gbWluX2QuZnJvbnQoKSA+IGxpbWl0KSB7CiAgICAgICAgICAgIGlmIChtYXhfZC5mcm9udCgpID09IG51bXNbaV0pIG1heF9kLnBvcF9mcm9udCgpOwogICAgICAgICAgICBpZiAobWluX2QuZnJvbnQoKSA9PSBudW1zW2ldKSBtaW5fZC5wb3BfZnJvbnQoKTsKICAgICAgICAgICAgaSsrOwogICAgICAgIH0KICAgICAgICByZXMgPSBtYXgocmVzLCBqIC0gaSArIDEpOwogICAgfQogICAgcmV0dXJuIHJlczsKfQoKaW50IG1haW4oKSB7CiAgICB2ZWN0b3I8aW50PiB0ZXN0ID0gezQsIDIsIDMsIDYsIDIsIDIsIDMsIDIsIDd9OwogICAgaW50IGxpbWl0ID0gMTsKICAgIGNvdXQgPDwgIkxvbmdlc3QgTi1zdGFibGU6ICIgPDwgbG9uZ2VzdFN1YmFycmF5KHRlc3QsIGxpbWl0KSA8PCBlbmRsOyAvLyBPdXRwdXQ6IDQKICAgIHJldHVybiAwOwp9