Leetcode每日一题——最长和谐子序列

文章目录

题目描述

和谐数组是指一个数组里元素的最大值和最小值之间的差别 正好是 1 。

现在,给你一个整数数组 nums ,请你在所有可能的子序列中找到最长的和谐子序列的长度。

数组的子序列是一个由数组派生出来的序列,它可以通过删除一些元素或不删除元素、且不改变其余元素的顺序而得到。

示例

示例 1:

输入:nums = [1,3,2,2,5,2,3,7]
输出:5
解释:最长的和谐子序列是 [3,2,2,2,3]

示例 2:

输入:nums = [1,2,3,4]
输出:2

示例 3:

输入:nums = [1,1,1,1]
输出:0

题解

class Solution(object):
    def findLHS(self, nums):
        nums = sorted(nums)
        a,b = 0,0
        m = 0
        while b < len(nums):
            while  nums[b] - nums[a] > 1:
                a += 1
            if nums[b] - nums[a] == 1:
                m = max(m, b - a + 1)
            b += 1
        return m

おすすめ

転載: blog.csdn.net/m0_52000372/article/details/121442843