Leetcode 673 Solution
This article provides solution to leetcode question 673 (number-of-longest-increasing-subsequence).
Access this page by simply typing in "lcs 673" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
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;
}
};