class Solution { public: int findNumberOfLIS(vector<int>& nums) { if (nums.size() == 0) return 0; pair<int,int> res = {0, 0}; // <length,count> vector<pair<int,int>> dp(nums.size(), {1,1}); // pair: length, count for (int i = 0; i < nums.size(); i++) { for (int j = 0; j < i; j++) { if (nums[j] < nums[i]) { if (dp[j].first + 1 == dp[i].first) { dp[i].second += dp[j].second; } else if (dp[j].first + 1 > dp[i].first) { dp[i].first = dp[j].first + 1; dp[i].second = dp[j].second; } } } } for (int i = 0; i < nums.size(); i++) { if (dp[i].first == res.first) res.second += dp[i].second; else if (dp[i].first > res.first) { res = dp[i]; } } return res.second; } };