UVA 10635 Prince and Princess—— 求LCS(最长公共子序列)转换成 求LIS(最长递增子序列)
题目大意:有n*n个方格,王子有一条走法,依次经过m个格子,公主有一种走法,依次经过n个格子(不会重复走),问他们删去一些步数后,重叠步数的最大值。
显然是一个LCS,我一看到就高高兴兴的打了个板子上去,结果TLE+RE。
仔细一看:n<=250,那么二维数组就得开250*250*250*250了,显然RE了。
所以我想着用滚动数组来存储,但是TLE又拦住了我的去路。
O(n^2)的效率就是62500*62500,大于10^8,所以1s之内完不成,所以要想别的办法。
偶然在网上找到了O(nlogn)的求LCS方法,发现正是这道题所需的:
这种方法的核心是把LCS转化成LIS求解,时间效率就可以下降到nlogn。
条件是一个数列中不能有重复项(正好与题目条件相符)。
不多说直接讲如何转化:
设两个数组是a[maxn]与b[maxn]。
在读入a的时候,将每一个a[ i ]映射到i。(map[ a [ i ] ] = i)
在读入b的时候,用b[ i ]去映射里面找有无对应的值,并新开一个数组来求LIS。(dp[ i ]=map[ b [ i ] ])
此时我们思考一下dp数组表示的含义:如果dp[ i ]==0——>b[ i ]在a[ i ]中无对应的值,当然不计算在最后结果里。
dp[ i ]!=0——>说明b[ i ]与a[ i ]中第i个数相等.
显然我们可以看出,这里a[ i ],b[ i ]都不需要,只需要用一个变量来代替就可以了,而且dp[ i ]==0的情况也不用考虑,算LIS的时候不可能带上它。
所以通过以上的步骤,我们就把LCS转化成了LIS,接下来用O(nlogn)的LIS二分优化写法求dp数组的最长上升子序列就可以了。
上代码:
#include <cstdio>
#include<algorithm>
#include <cstring>
const int maxn = 250*250+10;
int n,len1,len2,ans,aa,bb,map[maxn],dp[maxn],low[maxn];
//map数组用来建立关联(直接用map容器也ok)
//dp数组用来储存新数列,并以他为基础求LIS
int main() {
int t;
scanf("%d", &t);//多组数据
for (int kk=1;kk<=t;kk++) {
memset(low, 0, sizeof(low));
memset(map, 0, sizeof(map));
memset(dp, 0, sizeof(dp));//每次开始计算新的一组时候要初始化。
scanf("%d%d%d", &n, &len1, &len2);//题目的一个坑 ,len1,len2是走的步数,实际上走的格数是步数加1
len1 ++; len2 ++; int cnt = 1;
for (int i = 1; i <= len1; i ++) {
scanf("%d", &aa);
map[aa] = i;
}
for (int i = 1; i <= len2; i ++) {
scanf("%d", &bb);
if (map[bb]) {
dp[cnt ++] = map[bb];
}//bb如果与之前的所有aa不存在关联,不用管他,有关联再算他
}
low[1] = dp[1]; ans = 1;
for (int i = 2; i <cnt; i ++) {
if (dp[i] > low[ans]) {
low[++ ans] = dp[i];
}
else {
int yy=std::lower_bound(low+1,low+ans+1,dp[i])-low;
low[yy] = dp[i];
}
}//这是二分优化LIS
printf("Case %d: %d\n", kk, ans);//注意输出格式,\n与space
}
return 0;
}
本题的主要思路就是LCS(n^2)------->LIS(nlogn)
一种压时间复杂度的好方法。
UVA 10635 Prince and Princess—— 求LCS(最长公共子序列)转换成 求LIS(最长递增子序列)的更多相关文章
- UVA 10635 Prince and Princess【LCS 问题转换为 LIS】
题目链接: http://acm.hust.edu.cn/vjudge/problem/visitOriginUrl.action?id=19051 题意: 有两个长度分别为p+1和q+1的由1到n2 ...
- uva 10635 Prince and Princess(LCS成问题LIS问题O(nlogn))
标题效果:有两个长度p+1和q+1该序列.的各种元素的每个序列不是相互同.并1~n^2之间的整数.个序列的第一个元素均为1. 求出A和B的最长公共子序列长度. 分析:本题是LCS问题,可是p*q< ...
- UVA - 10635 Prince and Princess(LCS,可转化为LIS)
题意:有两个长度分别为p+1和q+1的序列,每个序列中的各个元素互不相同,且都是1~n2的整数.两个序列的第一个元素均为1.求出A和B的最长公共子序列长度. 分析: A = {1,7,5,4,8,3, ...
- Uva 10635 Prince and Princess (LCS变形LIS)
直接LCS是时间复杂度是O(p*q)的,但是序列元素各不相同,只要把其中一个序列映射成有序的, 另外一个序列再做相同的映射,没有的直接删掉,就变成了求另一个序列LIS. #include<bit ...
- uva 10635 - Prince and Princess(LCS)
题目连接:10635 - Prince and Princess 题目大意:给出n, m, k,求两个长度分别为m + 1 和 k + 1且由1~n * n组成的序列的最长公共子序列长的. 解题思路: ...
- UVA - 10635 Prince and Princess LCS转LIS
题目链接: http://bak.vjudge.net/problem/UVA-10635 Prince and Princess Time Limit: 3000MS 题意 给你两个数组,求他们的最 ...
- UVA 10635 - Prince and Princess LCS转化为LIS
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...
- Uva 10635 - Prince and Princess LCS/LIS
两个长度分别为p+1和q+1的由1到n2之前的整数组成的序列,每个序列的元素各不相等,两个序列第一个元素均为1.求两个序列的最长公共子序列 https://uva.onlinejudge.org/in ...
- [题解]UVa 10635 Prince and Princess
讲一下题目大意,就是有两个长度为p + 1和q + 1的序列,求它们的LCS. 如果用O(pq)的算法对于这道题来说还是太慢了.所以要另外想一些方法.注意到序列中的所有元素都不相同,所以两个序列中数对 ...
随机推荐
- linux系统的默认用户
1.可以通过cat /etc/passwd |cut -f1 -d: 可以提取/etc/passwd文件的第一个字段 2.也可以通过vipw进入vi编辑器来查看该文件每一行的第一个字段 linux ...
- 第2课 - 搭建Lua开发环境
第2课 - 搭建Lua开发环境 1. Lua 的优点 (1)Lua 使用标准的 ANSI C 进行开发,可以无缝集成到宿主程序,且几乎支持所有平台. (2)Lua 是开源且免费的软件,以源码的方式直接 ...
- 【深入理解Linux内核架构】3.3 页表
页表:用于建立用户进程空间的虚拟地址空间和系统物理内存(内存.页帧)之间的关联. 向每个进程提供一致的虚拟地址空间. 将虚拟内存页映射到物理内存,因而支持共享内存的实现. 可以在不增加物理内存的情况下 ...
- zepto | 用事件委托去解决无法给新增添的DOM添加事件的问题
前段时间在做一个任务的时候,碰见了一个问题:zepto无法用on事件去监听新增加的dom事件.这个问题用live可解决, 但是live在ios下失效,为了解决这个问题,我采用了暴力的方法去解决,每次添 ...
- 在思科三层交换机上配置DHCP,不同网段/VLAN间互通
摘要: 描述:在三层交换机上配置DHCP,实现DHCP为PC1/PC3分配192.168.1.X网段:实现DHCP为PC2/PC4分配192.168.2.X网段:并且各个PC间要可以互相通信.(文末附 ...
- OpenCV计算机视觉学习(1)——图像基本操作(图像视频读取,ROI区域截取,常用cv函数解释)
1,计算机眼中的图像 我们打开经典的 Lena图片,看看计算机是如何看待图片的: 我们点击图中的一个小格子,发现计算机会将其分为R,G,B三种通道.每个通道分别由一堆0~256之间的数字组成,那Ope ...
- P4395 [BOI2003]Gem 气垫车
树形dp 首先,我们可以考虑dp,把这个问题看成一个树的染色问题,用dp[i][j]表示以i为根节点,将树染成第i种颜色的最小代价,那么我们可以得到j的最大值是(log(maxn)/log(2)+1) ...
- tomcat在linux下安装
1.下载地址: https://tomcat.apache.org/download-90.cgi 2.上传linux 3.查看是否上传成功 4.解压: 5.进入后,查看README.md文件,可以查 ...
- 简单聊聊 Ironic
上一篇文章里我简单介绍了一下「裸金属」的概念,提到了 OpenStack 中的核心项目 Ironic,今天简单来聊聊它. Ironic 项目的吉祥物 Bare Metal 所以用 Bear 来做吉祥物 ...
- Django在Linux上uwsgi 与nginx的问题与解决
1.出现只有weclome to nginx 多半是是nginx的配置文件没有修改,把他的路由注释掉. 我是修改错文件夹了,一直在自己下载而非运行的文件夹修改 2.出现502 出现了多次502这里一一 ...