O(mn)实现LCIS
来源:互联网 发布:钢铁力量里孔雀的数据 编辑:程序博客网 时间:2024/04/29 08:25
序:
LCIS即求两序列的最长公共不下降子序列。思路于LCS基本一致。
用dp[i][j]记录当前最大值。
代码实现:
/*About: LCIS O(mn)Auther: kongse_qiDate:2017/04/26*/#include <bits/stdc++.h>#define maxn 505using namespace std;int n, m, a[maxn], b[maxn];void Init(){ scanf("%d%d", &n, &m); for(unsigned i = 0; i != n; ++i) { scanf("%d", &a[i]); } for(unsigned i = 0; i != m; ++i) { scanf("%d", &b[i]); } return ;}int Lcis(){ int maxx, dp[maxn][maxn], ans = 0; for(unsigned i = 1; i != n+1; ++i) { maxx = 0; for(unsigned j = 0; j != m; ++j) { dp[i][j] = dp[i-1][j]; if(a[i-1] > b[j]) { maxx = max(dp[i-1][j], maxx); } if(a[i-1] == b[j]) { dp[i][j] = maxx+1; maxx = max(maxx, dp[i-1][j]); } } } for(unsigned i = 0; i != m; ++i) { ans = max(ans, dp[n][i]); } return ans;}int main(){ //freopen("test.in", "r", stdin); Init(); cout << Lcis(); return 0;}
空间也是O(n^2),仔细阅读则会发现依然可以滚动数组,是空间复杂度降到O(n)。
与LCS的方式完全一致。
int Lcis(){ int maxx, dp[2][maxn], ans = 0; memset(dp, 0, sizeof dp); for(unsigned i = 1; i != n+1; ++i) { maxx = 0; for(unsigned j = 0; j != m; ++j) { dp[i&1][j] = dp[(i&1)^1][j]; if(a[i-1] > b[j]) { maxx = max(dp[(i&1)^1][j], maxx); } if(a[i-1] == b[j]) { dp[i&1][j] = maxx+1; maxx = max(maxx, dp[(i&1)^1][j]); } } } for(unsigned i = 0; i != m; ++i) { ans = max(ans, dp[n&1][i]); } return ans;}
但是这么做要注意,当你开的数组不是全局变量的时候一定要先memset为0,否则会出现一些神奇的情况。
(第一次调用的a[(i&1)^1][j]的值是系统的随机值,但是应该是0)
至此结束。
箜瑟_qi 2017.04.26
1 0
- O(mn)实现LCIS
- python实现的prim算法求MST O(MN)
- 最长公共子序列模板(O(mn))
- mn
- mn
- LCIS O(n ^ 2) 详解
- HDU 5904:LCIS(LCIS)
- 最长公共上升子序列(LCIS)的O(n^2)算法
- 最长公共上升子序列(LCIS)的O(n^2)算法
- 最长公共上升子序列(LCIS)的O(n^2)算法
- 最长公共上升子序列(LCIS)问题的O(n^2)解法
- HDU5904 LCIS (DP)
- LCIS
- LCIS
- LCIS
- LCIS
- LCIS
- LCIS
- java创建http接口,及调用
- 深入理解 CSS3 弹性盒布局模型
- ios 实现微信的非最近会话聊天界面的返回按钮
- opencv3.2+opencv_contrib+cmake
- Hbuilder-WebView相关
- O(mn)实现LCIS
- C#图片截取块并画在画板上带白边框带添加文字,截取支付宝的付款码
- MyCat生产实践--一致性hash分片&扩容
- The Log: What every software engineer should know about real-time data's unifying abstraction
- 架构设计之Spring-Session分布式集群会话管理
- 一次泛微OA宕机事件的解决。
- 条件编译#if
- Android返回键退出程序的两种实现
- Vue框架引入JS库的正确姿势