Skip to content
LC-2401 Medium LeetCode

2401. Longest Nice Subarray

Read the full problem statement on LeetCode.
Difficulty: medium Acceptance: 65% Topics: Array, Bit Manipulation, Sliding Window
View full problem on LeetCode
Reference solution (spoiler · python)
# Time:  O(n)
# Space: O(1)

# sliding window, two pointers
class Solution(object):
    def longestNiceSubarray(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        result = left = curr = 0
        for right in xrange(len(nums)):
            while curr&nums[right]:
                curr ^= nums[left]
                left += 1
            curr |= nums[right]
            result = max(result, right-left+1)
        return result

Solution from kamyu104/LeetCode-Solutions · MIT