Codeforces 10D LCIS 求最长公共上升子序列及输出这个子序列 dp
版权声明:本文为博主原创文章,未经博主同意不得转载。
https://blog.csdn.net/qq574857122/article/details/34430283
题目链接:点击打开链接
题意:
给定n长的一个序列
再给定k长的一个序列
求LCIS并输出这个子序列
如有多解输出随意解。。
= - = 敲的时候听着小曲儿pre的含义还没有想清楚。万万没想到就过了。。
。
#include<stdio.h>
#include<iostream>
#include<string.h>
#include<set>
#include<vector>
#include<map>
#include<math.h>
#include<string>
#include<stdlib.h>
#include<algorithm>
using namespace std;
#define N 505
int a[N],s[N];
int n, k;
int dp[N][N];
int pre[N][N][2];
int is[N][N];
vector<int>G;
int main(){
int i,j,co;
while(~scanf("%d",&n)){
G.clear();
for(i=1;i<=n;i++)scanf("%d",&a[i]);
scanf("%d",&k);
for(i=1;i<=k;i++)scanf("%d",&s[i]);
memset(dp, 0, sizeof dp);
memset(pre, 0, sizeof pre);
memset(is, 0, sizeof is);
for(i=1;i<=n;i++) {
int maxx = 0;
int x = 0, y = 0;
for(j=1;j<=k;j++)
{
dp[i][j] = dp[i-1][j];
if(a[i]>s[j] && maxx < dp[i-1][j]) {
maxx = dp[i-1][j];
if(is[i-1][j])
x = i-1, y = j;
else {
x = pre[i-1][j][0];
y = pre[i-1][j][1];
}
}
if(a[i]==s[j]) {
is[i][j] = 1;
dp[i][j] = maxx + 1;
if(is[x][y])
pre[i][j][0] = x, pre[i][j][1] = y;
else {
pre[i][j][0] = pre[x][y][0];
pre[i][j][1] = pre[x][y][1];
}
continue;
}
if(is[i-1][j])
pre[i][j][0] = i-1, pre[i][j][1] = j;
else {
pre[i][j][0] = pre[i-1][j][0];
pre[i][j][1] = pre[i-1][j][1];
}
}
}
int ans = 0;
int x = n, y = k;
for(i=1;i<=k;i++)if(ans<dp[n][i]){
ans = dp[n][i];
x = n, y = i;
}
printf("%d\n",ans);
if(!ans)continue;
while(x+y) {
if(is[x][y])G.push_back(a[x]);
int x1 = pre[x][y][0];
int y1 = pre[x][y][1];
x = x1 , y = y1;
}
for(i=G.size()-1; i>=0; i--){
printf("%d",G[i]);
i?
printf(" "):puts("");
}
}
return 0;
}
/*
2
1 2
3
1 2 3
*/Codeforces 10D LCIS 求最长公共上升子序列及输出这个子序列 dp的更多相关文章
- 后缀数组(模板题) - 求最长公共子串 - poj 2774 Long Long Message
Language: Default Long Long Message Time Limit: 4000MS Memory Limit: 131072K Total Submissions: 21 ...
- [algorithm]求最长公共子序列问题
最直白方法:时间复杂度是O(n3), 空间复杂度是常数 reference:http://blog.csdn.net/monkeyandy/article/details/7957263 /** ** ...
- poj 2774 Long Long Message,后缀数组,求最长公共子串 hdu1403
题意:给出两个字符串,求最长公共子串的长度. 题解:首先将两个字符串连在一起,并在中间加一个特殊字符(字串中不存在的)切割,然后两个串的最长公共字串就变成了全部后缀的最长公共前缀.这时就要用到heig ...
- POJ 2774 Long Long Message (二分 + Hash 求最长公共子串)题解
题意:求最长公共子串 思路:把两个串Hash,然后我们把短的作为LCS的最大可能值,然后二分长度,每次判断这样二分可不可以.判断时,先拿出第一个母串所有len长的子串,排序,然后枚举第二个母串len长 ...
- 算法 -- 求最长公共字符串&PHP
https://blog.csdn.net/hongyuancao/article/details/83308093 本文是利用PHP,求最长公共字符串.思路:利用动态规划和矩阵的思想. 动态规划:就 ...
- HDU 4681 string 求最长公共子序列的简单DP+暴力枚举
先预处理,用求最长公共子序列的DP顺着处理一遍,再逆着处理一遍. 再预处理串a和b中包含串c的子序列,当然,为了使这子序列尽可能短,会以c 串的第一个字符开始 ,c 串的最后一个字符结束 将这些起始位 ...
- 文本比较算法Ⅱ——Needleman/Wunsch算法的C++实现【求最长公共子串(不需要连续)】
算法见:http://www.cnblogs.com/grenet/archive/2010/06/03/1750454.html 求最长公共子串(不需要连续) #include <stdio. ...
- 求最长公共子串 Longest Common Subsequence
最长公共子串 // Longest Common Subsequence 子串有别于子序列, 子串是连续的, 而子序列可以不连续 /*--------------------------------- ...
- 计蒜之道 初赛 第三场 题解 Manacher o(n)求最长公共回文串 线段树
腾讯手机地图 腾讯手机地图的定位功能用到了用户手机的多种信号,这当中有的信号的作用范围近.有的信号作用的范围则远一些.有的信号相对于用户在不同的方位强度是不同的,有的则是在不论什么一个方向上信号强度都 ...
随机推荐
- 洛谷P3294 [SCOI2016]背单词——题解
题目传送 阅读理解题题意解释可以看这位大佬的博客. 发现求后缀与倒序求前缀是等价的,而找前缀自然就想到了trie树.将所有字符串翻转后再建入trie树中,再对每一个字符串翻转后从trie树中找前缀,就 ...
- JS框架_(Popup.js)3D对话框窗口插件
百度云盘 传送门 密码:afdo 3D对话框窗口插件效果: <!doctype html> <html lang="zh"> <head> &l ...
- sqli-labs(38)
0X01 ?id=' and 1=1%23 正确 ?id=1' and 1=2%23 错误 存在注入 0x1 堆叠注入讲解 (1)前言 国内有的称为堆查询注入,也有称之为堆叠注入.个人认为称之为堆叠注 ...
- [CSP-S模拟测试]:Cover(单调栈++单调队列+DP)
题目传送门(内部题126) 输入格式 第一行两个个整数$n,m$表示区间的长度与彩灯的数量. 接下来$m$行,每行三个整数$l_i,r_i,a_i$表示一条彩灯能够覆盖的区间以及它的美观程度. 输出格 ...
- Zookeeper基础命令操作
转载链接:https://blog.csdn.net/dandandeshangni/article/details/80558383 安装参考链接https://blog.csdn.net/qiun ...
- LeetCode 12. 整数转罗马数字(Integer to Roman)
题目描述 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II , ...
- csp2019 Emiya家今天的饭题解
qwq 由于窝太菜了,实在是不会,所以在题解的帮助下过掉了这道题. 写此博客来整理一下思路 正文 传送 简化一下题意:现在有\(n\)行\(m\)列数,选\(k\)个数的合法方案需满足: 1.一行最多 ...
- docker-compose部署zk和kafka
version: '3.4' services: zk1: image: zookeeper restart: always hostname: zk1 container_name: zk1 por ...
- xstream解析xml时遇到特殊字符出错
在xml中有"&"符号时,解析xml出错 解决办法: 将&替换成&
- office 安装破解
1. 打开Office Tool Plus.exe部署 2. 添加产品 `excel` `prowerpoint` `word` 3. 选择安装文件管理 选择下载安装 4.安装完成后点击开始部署 5. ...