博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CH 5101 最长公共上升子序列
阅读量:7061 次
发布时间:2019-06-28

本文共 1345 字,大约阅读时间需要 4 分钟。

题解:F[i][j] 表示 对于第一个数列枚举到i来说, 第二个数列以j结尾的最大长度是多少。

那么对于更新 F[i] -> F[i+1]来说  如果 a[i+1] == b[j] 那么我们就可以找到前面最大F[i][k]( k < j && b[k] < a[i+1])的值, 把他更新。

否则就F[i+1][j] = F[i][j]

最后对于所有的 F[n][k] 找到最大值就好了。

代码:

  

#include
using namespace std;#define Fopen freopen("_in.txt","r",stdin); freopen("_out.txt","w",stdout);#define LL long long#define ULL unsigned LL#define fi first#define se second#define pb push_back#define lson l,m,rt<<1#define rson m+1,r,rt<<1|1#define lch(x) tr[x].son[0]#define rch(x) tr[x].son[1]#define max3(a,b,c) max(a,max(b,c))#define min3(a,b,c) min(a,min(b,c))typedef pair
pll;const int inf = 0x3f3f3f3f;const LL INF = 0x3f3f3f3f3f3f3f3f;const LL mod = (int)1e9+7;const int N = 3e3 + 100;int a[N], b[N];int f[N][N];int main(){ int n; scanf("%d", &n); for(int i = 1; i <= n; ++i) scanf("%d", &a[i]); for(int i = 1; i <= n; ++i) scanf("%d", &b[i]); for(int i = 1; i <= n; ++i){ int val = 0; for(int j = 1; j <= n; ++j){ if(a[i] == b[j]) f[i][j] = val + 1; else f[i][j] = f[i-1][j]; if(b[j] < a[i]) val = max(val, f[i-1][j]); } } int ans = 0; for(int i = 1; i <= n; i++) ans = max(ans, f[n][i]); printf("%d\n", ans); return 0;}
View Code

 

转载于:https://www.cnblogs.com/MingSD/p/9928014.html

你可能感兴趣的文章
解决问题:Appium Android WebView 测试执行,从源生切换至WebView不稳定。超时后报chrome not reachable...
查看>>
day03_函数
查看>>
Django启程篇
查看>>
Educational Codeforces Round 24 E. Card Game Again[数论][线段树]
查看>>
谈谈游戏
查看>>
Javascript ----函数表达和形参实参
查看>>
PHP 防恶意刷新实现代码
查看>>
全文检索、数据挖掘、推荐引擎系列3---全文内容推荐引擎之中文分词
查看>>
软件工程—软件可靠性测试
查看>>
个人阅读计划
查看>>
SQL Server 查看数据页面
查看>>
angularJS的过滤器!
查看>>
微信小程序 --- Image组件
查看>>
sql 获取一个周的周一和周日
查看>>
zepto源码分析-代码结构【转载】
查看>>
nginx+uwsgi+Django部署线上环境
查看>>
jQuery 包装集
查看>>
CCNA Cloud CLDFND 210-451 QUIZ: Server Virtualization
查看>>
应用层各协议用的端口
查看>>
VMware workstation转到vsphere解决办法
查看>>