Leetcode 673 Solution

This article provides solution to leetcode question 673 (number-of-longest-increasing-subsequence).

https://leetcode.com/problems/number-of-longest-increasing-subsequence

Solution

class Solution {
public:
    int findNumberOfLIS(vector<int>& nums) {
        if (nums.size() == 0)
            return 0;

        vector<int> ms(nums.size(), 1);
        vector<int> ms_cnt(nums.size(), 1);

        int max_len = 0;
        int max_cnt = 0;
        
        for (int i = 0; i < nums.size(); i++)
        {
            for (int j = 0; j < i; j++)
            {
                if (nums[i] > nums[j])
                {
                    if (ms[i] < ms[j] + 1)
                    {
                        ms[i] = ms[j] + 1;
                        ms_cnt[i] = ms_cnt[j];
                    }
                    else if (ms[i] == ms[j] + 1)
                        ms_cnt[i] += ms_cnt[j];
                }
            }

            if (max_len < ms[i])
            {
                max_len = ms[i];
                max_cnt = ms_cnt[i];
            }
            else if (max_len == ms[i])
                max_cnt += ms_cnt[i];
        }
        
        return max_cnt;
    }
};