最长上升子序列c++

题目

输入样例:

复制代码
7
3 1 2 1 8 5 6

输出样例:

复制代码
4
思路

题目求最大长度,考虑使用DP来做。我们从状态表示和状态计算两方面进行分析。

假设用a数组来存序列,f数组来存以fi结尾的最长上升子序列。

  1. 状态表示:

这一步我们思考如何定义集合。

集合f(i)定义:以fi结尾的所有序列。

集合属性(即fi存的值):最大长度。

因为题目要求最长上升子序列,通过这样定义集合,我们可以枚举所有序列,并可以求出所有以fi结尾的最长上升子序列,那我们就可以fi中选出一个最大的作为答案了。

  1. 状态计算:

这一步我们思考如何把每个fi求出来。

要计算以fi结尾的最长上升子序列,那么我们可以利用在ai这个数之前算过的最长上升子序列fj,如果aj 小于 ai,说明ai 是可以放到aj后面 成为一条长度为fj + 1的上升子序列的。如果ai能放到多条fj后面,那么以ai结尾的最长上升子序列为fi = max(fi, fj + 1)。

代码
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N = 1010;
int a[N], f[N];

int main()
{
  int n;
  cin >> n;
  
  for (int i = 1; i <= n; i ++)
  cin >> a[i];
  
  int res = 1;
  for (int i = 1; i <= n; i ++)
  { f[i] = 1;
    for (int j = i - 1; j >= 0; j --)
    if (a[i] > a[j])
    f[i] = max(f[i], f[j] + 1);
    
    res = max(res, f[i]);
  }
  
  cout << res;
  return 0;
}
相关推荐
无限的鲜花3 小时前
反射(原创推荐)
java·开发语言
yongche_shi4 小时前
ragas官方文档中文版(五十)
开发语言·python·ai·ragas·如何评估和改进 rag 应用
一路向北he4 小时前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
QiLinkOS4 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
mit6.8244 小时前
阅读的核心,是再读
c++
AI行业学习5 小时前
Notepad++ 官方下载 + 完整安装 + 全套优化配置(2026最新)
开发语言·人工智能·python·前端框架·html·notepad++
大圣编程6 小时前
Python中continue语句的用法是什么?
开发语言·前端·python
upgrador6 小时前
基础知识:C++ STL构造函数的左闭右开惯例及其实现原理
开发语言·c++
yoothey7 小时前
报废审批流规则引擎设计——责任链模式完整实现
linux·开发语言·bash
geovindu8 小时前
python: Functional Options Pattern
开发语言·后端·python·设计模式·惯用法模式·函数式选项模式