力扣2401.最长优雅子数组

力扣2401.最长优雅子数组

  • 用mask处理此前所有数的1的位置

    • 删去nums[j]时用 ^ 是因为之前^过 再^一次就没了
cpp 复制代码
  class Solution {
  public:
      int longestNiceSubarray(vector<int>& nums) {
          int res=0;
          int mask = 0;
          for(int i=0,j=0;i<nums.size();i++)
          {
              while((mask & nums[i]) != 0) mask ^= nums[j++];
              //再把nums[i] ^上
              mask ^= nums[i];
              res = max(res,i-j+1);
          }
          return res;
      }
  };
相关推荐
vivo互联网技术5 分钟前
vivo官网APP首页端智能业务实践
前端·深度学习·算法
JK0x075 分钟前
代码随想录算法训练营 Day49 图论Ⅰ 深度优先与广度优先
算法·深度优先·图论
刚入坑的新人编程31 分钟前
高阶数据结构——红黑树实现
数据结构
maozexijr40 分钟前
Flink的时间问题
javascript·算法·flink
LDG_AGI1 小时前
【深度学习】多目标融合算法(六):渐进式分层提取模型PLE(Progressive Layered Extraction)
人工智能·深度学习·神经网络·算法·机器学习·推荐算法
奔跑的废柴1 小时前
LeetCode 925. 长按键入 java题解
java·算法·leetcode·双指针
姬公子5211 小时前
leetcode hot100刷题日记——7.最大子数组和
c++·算法·leetcode
闻缺陷则喜何志丹1 小时前
【回溯 剪支 状态压缩】# P10419 [蓝桥杯 2023 国 A] 01 游戏|普及+
c++·算法·蓝桥杯·剪枝·回溯·洛谷·状态压缩
Wneosy2 小时前
第十六届C++B组easyQuestions
c++·算法·蓝桥杯
赵和范2 小时前
C++:与7无关的数
开发语言·c++·算法