数据范围1e5 考虑nlog 或者n的解法,考虑双指针
因为这里要求的是一段连续的数组 想起我们的最长不重复连续子序列 然后结合一下位运算就好了文章来源:https://www.toymoban.com/news/detail-736796.html
是一道双指针不错的题目文章来源地址https://www.toymoban.com/news/detail-736796.html
class Solution {
public:
int longestNiceSubarray(vector<int>& nums) {
int n = nums.size();
int a = 0;
int ans = 1;
for(int i=0,j=0;i<n;i++){
a|=nums[i];
j = max(j,i);
while(j+1<n&&((a&nums[j+1])==0)) {
a|=nums[++j];
}
ans = max(ans,j-i+1);
a^=nums[i];
}
return ans;
}
};
到了这里,关于LeetCode 2401.最长优雅子数组 ----双指针+位运算的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!