力扣2401.最长优雅子数组

力扣2401.最长优雅子数组

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

    • 删去numsj时用 ^ 是因为之前^过 再^一次就没了
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;
      }
  };
相关推荐
社交怪人12 小时前
【奇偶ASCII值】信息学奥赛一本通C语言解法(题号1042)
算法
小欣加油12 小时前
leetcode3635 最早完成陆地和水上游乐设施的时间II
数据结构·c++·算法·leetcode
GUO_PP12 小时前
win11英雄联盟打开以后,自动改变音效,开启免提模式的问题修正
人工智能·算法
变量未定义~12 小时前
排列数字、 n-皇后问题
数据结构·算法
BirdenT13 小时前
20260604紫题训练
c++·算法
元启数宇13 小时前
疏散指示AI实战:规范布点与路径推演全流程
人工智能·算法
tg:;13 小时前
Catkin 常用命令
开发语言·c++·算法
暖阳华笺13 小时前
【高频考点】回溯(暴力搜索)
数据结构·c++·算法·回溯法
hunterkkk(c++)13 小时前
学习dijkstra算法(c++)
c++·学习·算法
Chensay.13 小时前
链表的基本操作(C语言版)
数据结构·链表