已解决
LeetCode 2401.最长优雅子数组 ----双指针+位运算
来自网友在路上 175875提问 提问时间:2023-11-02 16:35:03阅读次数: 75
最佳答案 问答题库758位专家为你答疑解惑
数据范围1e5 考虑nlog 或者n的解法,考虑双指针
因为这里要求的是一段连续的数组 想起我们的最长不重复连续子序列 然后结合一下位运算就好了
是一道双指针不错的题目
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;}
};
查看全文
99%的人还看了
相似问题
猜你感兴趣
版权申明
本文"LeetCode 2401.最长优雅子数组 ----双指针+位运算":http://eshow365.cn/6-30330-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!
- 上一篇: 腾讯云向量数据库正式对外全量开放公测
- 下一篇: 项目综合实训,vrrp+bfd,以及策略路由的应用