最长上升子序列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;
}
相关推荐
8Qi84 分钟前
LeetCode 746:使用最小花费爬楼梯 —— 题解笔记
java·笔记·算法·leetcode·动态规划
曾几何时`10 分钟前
Go(四)Channel
开发语言·后端·golang
未若君雅裁17 分钟前
Java 线程基础:进程、线程、并发并行、创建方式与生命周期
java·开发语言
sugar__salt19 分钟前
JS正则表达式与字符串高阶实战精讲
开发语言·javascript·正则表达式
QT-Neal21 分钟前
C/C++ 程序段的概念与分类
c语言·c++
AI浩23 分钟前
梯度累积与 Micro-Batch 设计分层式精讲:有效批次、显存边界与分布式同步
开发语言·分布式·batch
未若君雅裁26 分钟前
死锁产生条件与诊断:jps、jstack、VisualVM
java·开发语言
再玩一会儿看代码26 分钟前
Java抽象类和接口区别_场景理解
java·开发语言·经验分享·笔记·python
枕星而眠32 分钟前
【数据结构】树与二叉树基础知识点总结
数据结构·c++·后端·算法·运维开发
于先生吖34 分钟前
Java消息队列优化抢单逻辑,同城搬家拉货多场景业务数据库架构设计
java·开发语言·数据库架构