最长递增子序列的个数
Tips
题目
给定一个未排序的整数数组, 找到最长递增子序列的个数.
示例
输入: [1,3,5,4,7]
输出: 2
解释: 有两个最长递增子序列, 分别是 [1, 3, 4, 7] 和 [1, 3, 5, 7].
输入: [2,2,2,2,2]
输出: 5
解释: 最长递增子序列的长度是1, 并且存在5个子序列的长度为1, 因此输出5.
题解
dp[i]
: 表示以nums[i]
结尾的最长递增子序列的长度.count[i]
: 表示以nums[i]
结尾的最长递增子序列的个数.
/**
* @param {number[]} nums
* @return {number}
*/
var findNumberOfLIS = function (nums) {
const n = nums.length
const dp = new Array(n).fill(1)
const count = new Array(n).fill(1)
let max = 1
for (let i = 1; i < n; i++) {
for (let j = 0; j < i; j++) {
if (nums[j] < nums[i]) {
// 说明找到了一个更长的递增子序列
if (dp[j] + 1 > dp[i]) {
dp[i] = dp[j] + 1
count[i] = count[j]
// 说明找到了另一个长度相同的递增子序列
} else if (dp[j] + 1 === dp[i]) {
count[i] += count[j]
}
}
}
max = Math.max(dp[i], max)
}
let ans = 0
for (let i = 0; i < n; i++) {
if (dp[i] === max) {
ans += count[i]
}
}
return ans
}