列表

详情


594. 最长和谐子序列

和谐数组是指一个数组里元素的最大值和最小值之间的差别 正好是 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 { public: int findLHS(vector<int>& nums) { } };

golang 解法, 执行用时: 68 ms, 内存消耗: 7.4 MB, 提交时间: 2021-06-18 11:54:23

func findLHS(nums []int) (res int) {
    mp := map[int]int{}
    for _, num := range nums {
        mp[num]++
        k, has := mp[num+1]
        if has {
            res = max(res, k+mp[num])
        }
        k, has = mp[num-1]
        if has {
            res = max(res, k+mp[num])
        }

    }
    return res

}


func max(x, y int) int {
	if x > y {
		return x
	}
	return y
}

上一题