洛谷 P1439 【模板】最长公共子序列LCS 解题报告
是一道十分经典的LCS问题
很容易想到 n 的一般算法:
主题代码如下:
for (int i = 1; i <= n; i++)
for (int j = 1; j <= n; j++){
dp[i][j] = max (dp[i-1][j], dp[i][j-1]);
if (a[i] == b[j]) dp[i][j] = max (dp[i][j], dp[i-1][j-1] + 1);
}
printf ("%d", dp[n][n]);
但往下看一眼数据范围 :

没错, n ≤100000 ,n²直接TLE
题目描述中提到了两组数都是 自然数1-n的一个排列
所以这题可以这么来做:
设两个数组分别为 a 和 b
对于每一个a数组中的数,一定有一个唯一对应的相等的b数组中的数
可以将a数组中的数看作 1,2,3,4,5......n
将b数组中的数也变为对应的值,假设变为数组c,可以发现,这变成了一个最长上升子序列LIS问题
当c中的数有一个上升子序列时,则这个序列在原数组中一定与a数组是公共的
模拟一遍样例:
先把第一列数看作 1, 2, 3, 4, 5。 则3对应1, 2对应2, 1对应3 .......
第二列数变为 3, 2, 1, 4, 5
最长上升子序列为 1, 4, 5 或 2, 4, 5或3, 4, 5
可以发现,这三个序列在原数组中都能找到相应的公共部分
所以答案为3
完整代码:
#include <bits/stdc++.h>
using namespace std;
#define f(i, r) for (int i = 1; i <= r; i++)
int n, x, a[100005], k[100005], len, q[100005];
int main(){
scanf ("%d", &n);
f (i, n) scanf ("%d", &x), k[x] = i;
f (i, n) scanf ("%d", &a[i]), a[i] = k[a[i]];
f (i, n){
if (a[i] > q[len]) q[++len] = a[i];
else{
int w = upper_bound (q + 1, q + len + 1, a[i]) - q;
q[w] = a[i];
}
}
printf ("%d", len);
return 0;
}
点一下左边的推荐吧!谢谢~~~
洛谷 P1439 【模板】最长公共子序列LCS 解题报告的更多相关文章
- 洛谷1439:最长公共子序列(nlogn做法)
洛谷1439:最长公共子序列(nlogn做法) 题目描述: 给定两个序列求最长公共子序列. 这两个序列一定是\(1\)~\(n\)的全排列. 数据范围: \(1\leq n\leq 10^5\) 思路 ...
- 洛谷P2516 [HAOI2010]最长公共子序列(LCS,最短路)
洛谷题目传送门 一进来就看到一个多月前秒了此题的ysn和YCB%%% 最长公共子序列的\(O(n^2)\)的求解,Dalao们想必都很熟悉了吧!不过蒟蒻突然发现,用网格图貌似可以很轻松地理解这个东东? ...
- 洛谷 P2516 [HAOI2010]最长公共子序列
题目传送门 解题思路: 第一问要求最长公共子序列,直接套模板就好了. 第二问要求数量,ans[i][j]表示第一个字符串前i个字符,第二个字符串前j个字符的最长公共子序列的数量 如果f[i][j]是由 ...
- 洛谷P2516 [HAOI2010]最长公共子序列
题目描述 字符序列的子序列是指从给定字符序列中随意地(不一定连续)去掉若干个字符(可能一个也不去掉)后所形成的字符序列.令给定的字符序列X="x0,x1,-,xm-1",序列Y=& ...
- 1006 最长公共子序列Lcs
1006 最长公共子序列Lcs 基准时间限制:1 秒 空间限制:131072 KB 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdks ...
- 动态规划之最长公共子序列LCS(Longest Common Subsequence)
一.问题描述 由于最长公共子序列LCS是一个比较经典的问题,主要是采用动态规划(DP)算法去实现,理论方面的讲述也非常详尽,本文重点是程序的实现部分,所以理论方面的解释主要看这篇博客:http://b ...
- 编程算法 - 最长公共子序列(LCS) 代码(C)
最长公共子序列(LCS) 代码(C) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 给定两个字符串s,t, 求出这两个字符串最长的公共子序列的长度. 字符 ...
- C++版 - Lintcode 77-Longest Common Subsequence最长公共子序列(LCS) - 题解
版权声明:本文为博主Bravo Yeung(知乎UserName同名)的原创文章,欲转载请先私信获博主允许,转载时请附上网址 http://blog.csdn.net/lzuacm. C++版 - L ...
- POJ 1458 Common Subsequence(最长公共子序列LCS)
POJ1458 Common Subsequence(最长公共子序列LCS) http://poj.org/problem?id=1458 题意: 给你两个字符串, 要你求出两个字符串的最长公共子序列 ...
随机推荐
- 解决编译warning:warning: ‘MeteringUnit::voltage_gain_’ will be initialized after [-Wreorder]
问题: 环境:ubuntu 12.04,g++版本4.6.3,编译目标文件时出现warnings: u1204@u1204-zhw:~/hwsvn/2sw/4prj_mips/UCP_rt5350/s ...
- HDOJ1075字典翻译(map应用)
#include<iostream> #include<cstdio> #include<map> #include<string> #include& ...
- 百度之星 hdu5701 中位数计数
http://acm.hdu.edu.cn/showproblem.php?pid=5701 给出一个序列,取其中的任何一个连续的序列,该序列的数从小到大排列,待更新,,, #include<i ...
- css关于内外边距的详细解释
贴图吧,图一眼明了. 无效果时候有 只有一个<div>啦啦啦</div> 只有padding时候有: padding详细设计时: 解释:padding是对内的,如padding ...
- 【jQuery】slice()方法的使用
[jQuery]slice()方法的使用 slice()方法:从已有的数组中返回选定的元素. 语法: arrayObj.slice(start, end) ...
- 通过DBCC整理Sqlserver数据库表索引碎片
昨天检查了一张效率极慢的表,两年多没有维护,逻辑扫描碎片高达99.%,于是开始对这个表进行重点跟踪和记录日志.今天用DBCC SHOWCONTIG WITH TABLERESULTS 命令检查了一下所 ...
- ViewController lifecyle(IOS学习)
斯坦福的ios教学视频笔记一张,如下
- 一个自动修改本地IP地址的BAT
set /a num1=%random%%%200+1+1 //生成随机数set ip=192.168.1.//ip 主体set ip1=%ip%%num1% //拼接两部分cmd /c netsh ...
- nodejs PK php全方位比较PHP的Node.js的优缺点
全方位比较PHP的Node.js的优缺点 http://www.techug.com/php-vs-node-js
- Flask07 Jinja2模板测试器、控制语句IF/FOR、变量/块 赋值、作用域、块级作用域
1 测试器及其使用 在模板中的 {{}} 可以书写测试器,格式如下 {{ 变量 is 测试器名称 }} 1.1 在python中导入 Jinja2 的模板 from jinja2 import te ...