leetcode673_go_最长递增子序列的个数
题目给定一个未排序的整数数组 , 找到最长递增子序列的个数 。
示例 1:输入: [1,3,5,4,7] 输出: 2
【leetcode673_go_最长递增子序列的个数】解释: 有两个最长递增子序列 , 分别是 [1, 3, 4, 7] 和[1, 3, 5, 7] 。
示例 2:输入: [2,2,2,2,2] 输出: 5
解释: 最长递增子序列的长度是1 , 并且存在5个子序列的长度为1 , 因此输出5 。
注意: 给定的数组长度不超过 2000 并且结果一定是32位有符号整数 。
解题思路分析1、动态规划;时间复杂度O(n^2) , 空间复杂度O(n)
文章插图
func findNumberOfLIS(nums []int) int { n := len(nums) if n == 0 || nums == nil {return 0 } dp := make([]int, n) count := make([]int, n) maxValue := 0 for i := 0; i < n; i++ {dp[i] = 1count[i] = 1for j := 0; j < i; j++ {if nums[j] < nums[i] {if dp[i] < dp[j]+1 {count[i] = count[j]} else if dp[i] == dp[j]+1 {count[i] = count[i] + count[j]}dp[i] = max(dp[j]+1, dp[i])}}maxValue = http://kandian.youth.cn/index/max(maxValue, dp[i]) } res := 0 for i := 0; i < n; i++ {if dp[i] == maxValue {res = res + count[i]} } return res}func max(a, b int) int { if a> b {return a } return b}总结Medium题目 , 题目意思同leetcode 300.最长上升子序列 , 额外借助一个数组存储个数
- 跨境电商拉开序幕,综合电商也要来分一杯羹|史上最长“黑五”·交锋| 考拉海购
- 真假难辨、运费高、清关慢……跨境电商怎么破?|史上最长“黑五”·大考 | 跨境
- 内置|续航时间最长的5部5G手机:小米拿到第一,网友:大电池就是好
- Apple Music年终福利来袭 可免费试用最长达五个月
- 力扣LeetCode 32最长有效括号(困难)
- 同级性能最强续航最长!卢伟冰:Redmi Note 9系列要做到同级No.1
- 最长|Redmi Note 9系列不仅拥有同级最长续航:电池品质高于行业标准
- 亚马逊海外购史上最长“真黑五”登场,西安消费者海淘偏爱汽车配件
- Redmi Note 9系列不仅拥有同级最长续航:电池品质高于行业标准
- 发话|卢伟冰发话,Redmi note9同级别性能最强、续航最长!
