力扣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;
      }
  };
相关推荐
老鼠只爱大米几秒前
LeetCode经典算法面试题 #295:数据流的中位数(双堆法、有序列表、平衡树等多种实现方案详解)
算法·leetcode·优先队列··数据流·中位数·java 面试题
x_xbx4 分钟前
LeetCode:215. 数组中的第K个最大元素
数据结构·算法·leetcode
黎阳之光10 分钟前
AI数智筑防线 绿色科技启新篇——黎阳之光硬核技术赋能生态安全双升级
大数据·人工智能·算法·安全·数字孪生
2501_9249526910 分钟前
C++中的过滤器模式
开发语言·c++·算法
2401_8732046512 分钟前
C++中的组合模式实战
开发语言·c++·算法
西野.xuan14 分钟前
内存布局(堆vs栈)一篇详解!!
java·数据结构·算法
2401_8318249617 分钟前
高性能压缩库实现
开发语言·c++·算法
2401_8747325325 分钟前
C++中的策略模式进阶
开发语言·c++·算法
大熊背28 分钟前
ISP离线模式应用(二)-如何利用 ISP 离线模式 加速 3DNR 收敛
linux·算法·rtos·isp pipeline·3dnr
zhangfeng113332 分钟前
`transformers` 的 `per_device_train_batch_size` 不支持小于 1 的浮点数值,llamafactory 支持
人工智能·算法·batch