力扣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;
      }
  };
相关推荐
TracyCoder12313 小时前
LeetCode Hot100(15/100)——54. 螺旋矩阵
算法·leetcode·矩阵
u01092727114 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_9418372614 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
探序基因15 小时前
单细胞Seurat数据结构修改分群信息
数据结构
六义义15 小时前
java基础十二
java·数据结构·算法
四维碎片15 小时前
QSettings + INI 笔记
笔记·qt·算法
Tansmjs15 小时前
C++与GPU计算(CUDA)
开发语言·c++·算法
独自破碎E16 小时前
【优先级队列】主持人调度(二)
算法
weixin_4454766816 小时前
leetCode每日一题——边反转的最小成本
算法·leetcode·职场和发展
打工的小王16 小时前
LeetCode Hot100(一)二分查找
算法·leetcode·职场和发展