Powered by:NEFU AB-IN
Link
文章目录
- 2401. 最长优雅子数组
- 题意
- 思路
- 代码
2401. 最长优雅子数组
题意
给你一个由 正 整数组成的数组 nums 。
如果 nums 的子数组中位于 不同 位置的每对元素按位 与(AND)运算的结果等于 0 ,则称该子数组为 优雅 子数组。
返回 最长 的优雅子数组的长度。
子数组 是数组中的一个 连续 部分。
注意:长度为 1 的子数组始终视作优雅子数组
思路
用滑动窗口优化,存在单调性,就是存在是或不是的分界线
- 子数组中任意两个数按位与均为 0,意味着任意两个数对应的集合的交集为空,题目的意思也就是说,这个数组里的数二进制位按位加起来,每一位二进制位最多为1
- 也就是这个集合中某个二进制位不能超过1,固定右端点,当来的值和集合维护的值进行AND运算>0,说明集合存在交集,所以指针左移,排除掉
- OR的操作用来给集合取并集,XOR的操作用来除去某个数的影响,也就是差
- 当维护好了,左边都是不符合,右边是符合,那么当前就是以r为右端点,最长的子数组
https://leetcode.cn/problems/longest-nice-subarray/solutions/1799426/bao-li-mei-ju-pythonjavacgo-by-endlessch-z6t6/
代码
# 3.8.19 import
import random
from collections import Counter, defaultdict, deque
from datetime import datetime, timedelta
from functools import lru_cache
from heapq import heapify, heappop, heappush, nlargest, nsmallest
from itertools import combinations, compress, permutations, starmap, tee
from math import ceil, comb, fabs, floor, gcd, log, perm, sqrt
from string import ascii_lowercase, ascii_uppercase
from sys import exit, setrecursionlimit, stdin
from typing import Any, Dict, List, Optional, Tuple, TypeVar, Union# Constants
TYPE = TypeVar('TYPE')
N = int(2e5 + 10)
M = int(20)
INF = int(1e12)
OFFSET = int(100)
MOD = int(1e9 + 7)# Set recursion limit
setrecursionlimit(int(2e9))class Arr:array = staticmethod(lambda x=0, size=N: [x() if callable(x) else x for _ in range(size)])array2d = staticmethod(lambda x=0, rows=N, cols=M: [Arr.array(x, cols) for _ in range(rows)])graph = staticmethod(lambda size=N: [[] for _ in range(size)])class Math:max = staticmethod(lambda a, b: a if a > b else b)min = staticmethod(lambda a, b: a if a < b else b)class IO:input = staticmethod(lambda: stdin.readline().rstrip("\r\n"))read = staticmethod(lambda: map(int, IO.input().split()))read_list = staticmethod(lambda: list(IO.read()))class Std:pass
# ————————————————————— Division line ——————————————————————class Solution:def longestNiceSubarray(self, nums: List[int]) -> int:l, ans, or_ = 0, 1, 0for r, num in enumerate(nums):while or_ & num:or_ ^= nums[l]l += 1or_ |= numans = Math.max(ans, r - l + 1)return ansSolution().longestNiceSubarray([1, 3, 8, 48, 10])