All Downloads are FREE. Search and download functionalities are using the official Maven repository.

g0501_0600.s0594_longest_harmonious_subsequence.Solution Maven / Gradle / Ivy

There is a newer version: 1.38
Show newest version
package g0501_0600.s0594_longest_harmonious_subsequence;

// #Easy #Array #Hash_Table #Sorting #2022_08_25_Time_16_ms_(95.95%)_Space_54.5_MB_(74.21%)

import java.util.Arrays;

/**
 * 594 - Longest Harmonious Subsequence\.
 *
 * Easy
 *
 * We define a harmonious array as an array where the difference between its maximum value and its minimum value is **exactly** `1`.
 *
 * Given an integer array `nums`, return _the length of its longest harmonious subsequence among all its possible subsequences_.
 *
 * A **subsequence** of array is a sequence that can be derived from the array by deleting some or no elements without changing the order of the remaining elements.
 *
 * **Example 1:**
 *
 * **Input:** nums = [1,3,2,2,5,2,3,7]
 *
 * **Output:** 5
 *
 * **Explanation:** The longest harmonious subsequence is [3,2,2,2,3]. 
 *
 * **Example 2:**
 *
 * **Input:** nums = [1,2,3,4]
 *
 * **Output:** 2 
 *
 * **Example 3:**
 *
 * **Input:** nums = [1,1,1,1]
 *
 * **Output:** 0 
 *
 * **Constraints:**
 *
 * *   1 <= nums.length <= 2 * 104
 * *   -109 <= nums[i] <= 109
**/
public class Solution {
    public int findLHS(int[] nums) {
        Arrays.sort(nums);
        int max = 0;
        int lastN = 0;
        int curN = 1;
        int cur = nums[0];
        for (int i = 1; i < nums.length; i++) {
            if (nums[i] > cur) {
                if (lastN > 0 && curN > 0 && lastN + curN > max) {
                    max = lastN + curN;
                }
                // if diff more than 1, don't count
                lastN = nums[i] - cur == 1 ? curN : 0;
                curN = 1;
                cur = nums[i];
            } else {
                curN++;
            }
        }
        if (lastN > 0 && curN > 0 && lastN + curN > max) {
            max = lastN + curN;
        }
        return max;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy