最长上升子序列c++

题目

输入样例:

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

输出样例:

复制代码
4
思路

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

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

  1. 状态表示:

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

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

集合属性(即f[i]存的值):最大长度。

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

  1. 状态计算:

这一步我们思考如何把每个f[i]求出来。

要计算以f[i]结尾的最长上升子序列,那么我们可以利用在a[i]这个数之前算过的最长上升子序列f[j],如果a[j] 小于 a[i],说明a[i] 是可以放到a[j]后面 成为一条长度为f[j] + 1的上升子序列的。如果a[i]能放到多条f[j]后面,那么以a[i]结尾的最长上升子序列为f[i] = max(f[i], f[j] + 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;
}
相关推荐
AA陈超39 分钟前
虚幻引擎UE5专用服务器游戏开发-20 添加基础能力类与连招能力
c++·游戏·ue5·游戏引擎·虚幻
mit6.8241 小时前
[Meetily后端框架] AI摘要结构化 | `SummaryResponse`模型 | Pydantic库 | vs marshmallow库
c++·人工智能·后端
screenCui1 小时前
macOS运行python程序遇libiomp5.dylib库冲突错误解决方案
开发语言·python·macos
R-G-B1 小时前
【02】MFC入门到精通——MFC 手动添加创建新的对话框模板
c++·mfc·mfc 手动添加创建新的对话框
linux kernel1 小时前
第七讲:C++中的string类
开发语言·c++
Tipriest_2 小时前
[数据结构与算法] 优先队列 | 最小堆 C++
c++·优先队列·数据结构与算法·最小堆
玩代码2 小时前
Java线程池原理概述
java·开发语言·线程池
宛西南浪漫戈命2 小时前
Centos 7下使用C++使用Rdkafka库实现生产者消费者
c++·centos·linq
泰勒疯狂展开2 小时前
Java研学-MongoDB(三)
java·开发语言·mongodb
zzywxc7872 小时前
AI技术通过提示词工程(Prompt Engineering)正在深度重塑职场生态和行业格局,这种变革不仅体现在效率提升,更在重构人机协作模式。
java·大数据·开发语言·人工智能·spring·重构·prompt