力扣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;
      }
  };
相关推荐
C语言不精4 分钟前
c语言-优雅的多级菜单设计与实现
c语言·开发语言·算法
AI科技星10 分钟前
张祥前统一场论:引力场与磁矢势的关联,反引力场生成及拉格朗日点解析(网友问题解答)
开发语言·数据结构·经验分享·线性代数·算法
C雨后彩虹12 分钟前
最少交换次数
java·数据结构·算法·华为·面试
-森屿安年-28 分钟前
二叉平衡树的实现
开发语言·数据结构·c++
foxsen_xia31 分钟前
go(基础01)——协程
开发语言·算法·golang
稚辉君.MCA_P8_Java34 分钟前
Gemini永久会员 Go 返回最长有效子串长度
数据结构·后端·算法·golang
jyyyx的算法博客38 分钟前
LeetCode 面试题 16.22. 兰顿蚂蚁
算法·leetcode
TL滕42 分钟前
从0开始学算法——第五天(初级排序算法)
数据结构·笔记·学习·算法·排序算法
Q741_1471 小时前
C++ 高精度计算的讲解 模拟 力扣67.二进制求和 题解 每日一题
c++·算法·leetcode·高精度·模拟
夏乌_Wx1 小时前
练题100天——DAY19:含退格的字符串+有序数组的平方
算法