力扣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;
      }
  };
相关推荐
吃好睡好便好1 小时前
用while循环语句求和
开发语言·学习·算法·matlab·信息可视化
王璐WL1 小时前
【C语言入门级教学】函数的概念2
c语言·数据结构·算法
不知名的忻2 小时前
B 树与 B+ 树:面试完全指南
b树·算法·面试·b+树
运筹vivo@3 小时前
2657. 找到两个数组的前缀公共数组 | 难度:中等
算法·leetcode·职场和发展·哈希表
索木木3 小时前
NCCL SHARP 和 TREE算法
java·服务器·算法
心中有国也有家4 小时前
hccl 架构拆解:昇腾集合通信库到底在做什么?
人工智能·经验分享·笔记·分布式·算法·架构
小O的算法实验室5 小时前
2026年MCS,Q-learning增强MOPSO与改进DWA融合算法+复杂三维地形下特定移动机器人动态路径规划
算法
Peter·Pan爱编程6 小时前
10. new_delete 不是 malloc_free 的包装
c++·人工智能·算法
不知名的老吴7 小时前
双栈秒杀表达式的生成方式
数据结构
故事和你917 小时前
洛谷-【动态规划1】动态规划的引入2
开发语言·数据结构·c++·算法·动态规划·图论