力扣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;
      }
  };
相关推荐
阿正的梦工坊13 小时前
【Rust】06-函数、控制流与模块组织
开发语言·算法·rust
阿正的梦工坊13 小时前
【Rust】16-async/await、Future 与执行器模型
网络·算法·rust
阿正的梦工坊14 小时前
【Rust】11-Rust 所有权模型的编译期推理机制
开发语言·算法·rust
风筝在晴天搁浅14 小时前
LeetCode CodeTop 88.合并两个有序数组
算法·leetcode·职场和发展
GuWen_yue14 小时前
吃透二叉树与递归!60分钟掌握树结构核心+解题思路
javascript·算法
happymaker062614 小时前
LeetCodeHot100——3.无重复字符的最长子串
算法
nice_lcj52014 小时前
排序(2)-选择排序专题——简单选择排序与堆排序的结构优化
数据结构·算法·排序算法
nice_lcj52014 小时前
排序(4)-归并排序专题——归并排序的分治美学
java·数据结构·算法·排序算法
洛水水14 小时前
【力扣100题】83.最小栈
算法·leetcode·职场和发展
无忧.芙桃14 小时前
数据结构之栈
c语言·开发语言·数据结构