力扣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;
      }
  };
相关推荐
x_xbx3 分钟前
LeetCode:21. 合并两个有序链表
算法·leetcode·链表
2501_945423543 分钟前
C++与Rust交互编程
开发语言·c++·算法
I_LPL7 分钟前
day54 代码随想录算法训练营 图论专题8
数据结构·图论·拓扑排序·dijkstra算法
我能坚持多久7 分钟前
【初阶数据结构10】——链式二叉树的功能实现
数据结构·算法
tankeven14 分钟前
HJ131 数独数组
c++·算法
liuyao_xianhui14 分钟前
优选算法_丢失的数字_位运算_C++
linux·数据结构·c++·算法·动态规划·哈希算法·散列表
woniu_buhui_fei15 分钟前
Java 服务最常见的线上性能故障
java·jvm·算法
sali-tec17 分钟前
C# 基于OpenCv的视觉工作流-章37-区域截图
图像处理·人工智能·opencv·算法·计算机视觉
DeepModel18 分钟前
【概率分布】正态分布(高斯分布)原理、可视化与机器学习实战
python·算法·概率论
啊哦呃咦唔鱼19 分钟前
LeetCode hot100-239 滑动窗口最大值
数据结构·算法·leetcode