最长上升子序列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;
}
相关推荐
不会C语言的男孩6 分钟前
C++ Primer Plus 第8章:函数探幽
开发语言·c++
William_wL_10 分钟前
【C++】模板进阶
c++
MC皮蛋侠客7 小时前
Google Test 单元测试指南
c++·单元测试·google test
方也_arkling8 小时前
【Java-Day08】static / final / 枚举
java·开发语言
艾莉丝努力练剑8 小时前
【Linux:文件】Ext系列文件系统进阶
linux·运维·服务器·c++·文件系统·文件io·ext
风吹夏回8 小时前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
Chengbei118 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1128 小时前
web-第一次课后作业
java·开发语言·idea
小熊Coding9 小时前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
秋99 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python