UVA 10635 Prince and Princess【LCS 问题转换为 LIS】-程序员宅基地

题目链接:

http://acm.hust.edu.cn/vjudge/problem/visitOriginUrl.action?id=19051

题意:

有两个长度分别为p+1q+1的由1n2之前的整数组成的序列,每个序列的元素各不相等,两个序列第一个元素均为1。求两个序列的最长公共子序列。

分析:

LCS的复杂度为O(pq),这题p,q最大为250 * 250,必T无疑。
注意题目说的每个序列的元素各不相等,那么就能保证我们可以把序列A的元素用1p+1重新进行赋值,把B中元素根据A的赋值找到对应的标号,用0表示没有出现过,那么问题就可以转化为LIS啦,时间复杂度O(nlogn),可以过了。
有关LIS的内容这里有一个http://blog.csdn.net/yukizzz/article/details/50620631

代码:

/*************************************************************************
    > File Name: 10635.cpp
    > Author: jiangyuzhu
    > Mail: [email protected] 
    > Created Time: Sat 18 Jun 2016 08:57:43 PM CST
 ************************************************************************/

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<queue>
#include<stack>
using namespace std;
#define sa(n) scanf("%d", &(n));
typedef pair<int, int>p;
const int maxn = 250 + 5, mod = 1e9 + 7, oo = 0x3f3f3f3f;
int a[maxn * maxn], b[maxn * maxn], nb[maxn * maxn];
int pos[maxn * maxn];
int dp[maxn * maxn];
int main (void)
{
    int t;sa(t);    
    for(int kas = 1; kas <= t; kas++){
        int n, p, q;sa(n);sa(p);sa(q);
        memset(pos, 0, sizeof(pos));
        for(int i = 0; i <= p; i++){
            sa(a[i]);
            pos[a[i]] = i;
        }
        memset(nb, 0, sizeof(nb));
        for(int i = 0; i <= q; i++){
            sa(b[i]);
            nb[i] = pos[b[i]];
        }
        memset(dp, 0x3f, sizeof(dp));
        for(int i = 0; i <= q; i++){
            *lower_bound(dp, dp + q + 1, nb[i]) = nb[i];
        }
        int ans = lower_bound(dp, dp + q + 1, oo) - dp;
        printf("Case %d: %d\n", kas, ans);
    }
    return 0;
}

转载于:https://www.cnblogs.com/Tuesdayzz/p/5758615.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/An55511/article/details/101633545

智能推荐

string与doule互相转换并保留两位小数_string转double保留两位小数-程序员宅基地

文章浏览阅读2.9k次。其实string与double、int的互转有一些函数可以直接用,例如: //doule转string string str1 = to_string(3.14); //int转string string str2 = to_string(4); //string转int int x= atoi(str2.c_str()); //string转double double y = stof(str1.c_str());但是不满足我想顺便四舍五入保留小数位的需求,所以自己写了两个函数。_string转double保留两位小数

azkaban任务报错java.lang.RuntimeException: The root scratch dir: /tmp/hive_azkaban kettle 时间长报错-程序员宅基地

文章浏览阅读3.2k次。azkaban运行任务的时候失败报错如下:23-03-2016 08:16:14 CST analyzer-kafka2hdfs_new ERROR - Exception in thread "main" org.apache.hive.service.cli.HiveSQLException: java.lang.RuntimeException: The root scratch d_azkaban kettle 时间长报错

PHP生成迅雷、快车、旋风等软件的下载链接代码实例-程序员宅基地

文章浏览阅读131次。<?php function Download() { $urlodd=explode('//',$_POST["url"],2);//把链接分成2段,//前面是第一段,后面的是第二段 $head=strtolower($urlodd[0]);//PHP对大小写敏感,先统一转换成小写,不然 出现HtTp:或者ThUNDER:这种怪异的写法不好处...

创建带有UTF-8 的声明的XMLDocument_xmlnewdoc utf-8-程序员宅基地

文章浏览阅读4.6k次。class Program { static void Main(string[] args) { // Create and load the XML document. XmlDocument doc = new XmlDocument(); string xmlString = "_xmlnewdoc utf-8

Jquery 多选下拉列表插件jquery multiselect-程序员宅基地

文章浏览阅读286次。有一个多选的需求,在网上找到了这个插件:multiselecthttps://github.com/ehynds/jquery-ui-multiselect-widgetcsdn博客上有这个插件的介绍,不少童鞋都问了这么个问题,怎么获取选中的值?真是个好问题,因为我在看demo的时候也发现了这个问题,呵呵!先简单说说这个插件: jquery-multisel..._multiselect 多级 多选插件 checkbox

解决android studio打包后安装APK提示“签名不一致,该应用可能已被修改。“_签名不一致该应用可能已被修改-程序员宅基地

文章浏览阅读8.4k次,点赞5次,收藏15次。现象解决办法修改applicationId名_签名不一致该应用可能已被修改

随便推点

Java金额每隔三位加上一个逗号_java金额三位数一个逗号-程序员宅基地

文章浏览阅读1.4w次,点赞5次,收藏5次。JAVA实现给数字加逗号:说明:将float类型的数据转换成以3位逗号隔开的字符串,并且保留两位有效数字 public static String formatTosepara(float data) {DecimalFormat df = new DecimalFormat("#,###.00"); return df.format(data);}如果保留整数,那么 De_java金额三位数一个逗号

使用Xcode GPU Frame Caputre教程-程序员宅基地

文章浏览阅读307次。http://blog.manbolo.com/2012/11/20/using-xcode-opengl-es-frame-capture这里是原文,因为它版本比较老和它demo的限制,所以也想写一个基于Xcode6上基于3d渲染的分析的教程 Xcode和Visual Studio的一个主要差别,还是再Xcode有一套免费的的性能工具,例如Instruments,不过对于图..._xcode frame capture 捕捉不到

新手不要再被误导!这是一篇最新的Xposed模块编写教程_xposedbridgeapi-82.jar-程序员宅基地

文章浏览阅读1.5k次,点赞3次,收藏7次。0x00 前言作者写于2018.11.21,我在转载时日期为2021.01.01,博客内容已经测试了,完全正确且可以运行,新手建议从此看起再看官方文档。在互联网上,关于Xposed模块编写的教程可谓是一抓一大把。但由于时间的推移,很多工具和方法都发生了变化(如Eclipse退出安卓编程舞台,AndroidStudio 不断升级导致其一些设置也随之变化等)也正因此,网上的教程往往有一些时限性,比如现如今 provide 这个关键字已经被舍弃了却仍有人在用,还有些说要把jar包放到lib文件夹而非lib_xposedbridgeapi-82.jar

SpringBoot异常处理_如何排除springboot默认的异常管理逻辑-程序员宅基地

文章浏览阅读288次。文章目录SpringBoot异常处理1. SpringBoot默认的异常处理方式1.1 原理分析1.2 取消默认异常处理逻辑2. 自定义异常处理逻辑2.1 方式一:实现ErrorPageRegistrar接口2.2 方式二:通过注解@ExceptionHandlerSpringBoot异常处理1. SpringBoot默认的异常处理方式1.1 原理分析SpringBoot内部已经进行了统一..._如何排除springboot默认的异常管理逻辑

第一范式、第二范式、第三范式、BCNF(BC范式)-程序员宅基地

文章浏览阅读7.6k次,点赞11次,收藏37次。范式原理笔记数据库关系数据理论----范式范式原理笔记什么是(范式)---范式介绍范式发展1、第一范式2、第二范式3、第三范式4、BCNF(扩展第三范式)什么是(范式)—范式介绍官方介绍,数据库中的关系是要满足一定要求的,满足不同程度要求的为不同范式。满足最低要求的叫第一范式,简称1NF;在第一范式中满足进一步要求的为第二范式,其余的一次类推。还不懂?那么简单来说范式是一种标准,也就是你设计表结构是要符合规范。就好像是你装修自己的房子,你按照的标准越高,那么你的房子就更加的牢固安全。所谓“第几范_第一范式

【openresty】API disabled in the context of init_worker_by_lua_api disabled in the current context-程序员宅基地

文章浏览阅读4.9k次。在调用init.lua初始化的过程中,我调用了mysql数据库接口初始化数据,然后就提示了此错误:2020/06/28 19:56:40 [error] 24673#24673: *7 [lua] init.lua:2: init , context: init_worker_by_lua*2020/06/28 19:56:40 [error] 24673#24673: *7 [lua] data.lua:11: load(): context: init_worker_by_lua*2020/0_api disabled in the current context

推荐文章

热门文章

相关标签