Skip to main content

最长递增子序列的个数

Tips

题目类型: Dynamic Programming

相关题目:

题目

给定一个未排序的整数数组, 找到最长递增子序列的个数.

示例
输入: [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
}