题目:http://poj.org/problem?id=2127

十分费劲地终于记录好了路径……用一个前驱。

这是 n^2 的LICS方法。其实就是 n ^ 2 log n 把“找之前的d [ j ]的max”用树状数组弄成了 n ^ 2,而这个则在每个 i 遍历 j 的时候顺便更新记录好了要用的那个值,就线性了。

j 是脚标。k 的更新有时间差,保证了“只能用脚标比自己小的”这个条件。

#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
int n,m;
bool use[][];
ll a[],b[],d[],pre[][][];//0是行,1是列;表示第i行与j匹配时
void print(ll cnt,ll k) //用了这个i吗?(和j匹配时)(use[i][j])
{ //上一个是?(行是0,上一行与pre[1]匹配时,以定位)
// printf("(cnt=%lld k=%lld)",cnt,k);
if(!cnt)return;
print(pre[][cnt][k],pre[][cnt][k]);
if(use[cnt][k])printf("%lld ",b[k]);//主要用在cnt==n时判断输出此i否
}
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%lld",&a[i]);
scanf("%d",&m);
for(int i=;i<=m;i++)scanf("%lld",&b[i]);
for(int i=;i<=n;i++)
{
ll k=;
for(int j=;j<=m;j++) //若没有选此i,行是之前的(就像d的自然copy一样)
{
if(use[i-][j])
{
pre[][i][j]=i-;pre[][i][j]=j;
}
else
{
pre[][i][j]=pre[][i-][j];pre[][i][j]=pre[][i-][j];
}
}
for(int j=;j<=m;j++)
{
if(a[i]>b[j]&&d[j]>d[k])k=j;
else if(a[i]==b[j]&&d[j]<d[k]+)//选此i
{
d[j]=d[k]+;
if(use[i-][k])
{
pre[][i][j]=i-;pre[][i][j]=k;
}
else
{
pre[][i][j]=pre[][i-][k];pre[][i][j]=k;//用的不是上一行的j,而是k
}
use[i][j]=;
}
}
}
ll mx=,k=;
for(int i=;i<=m;i++)
if(d[i]>mx)mx=d[i],k=i;
printf("%lld\n",mx);
print(n,k);
return ;
}

为什么这个比上一个慢?

#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
int n,m;
bool use[][];
ll a[],b[],d[],pre[][][];//0是行,1是列;表示第i行与j匹配时
void print(ll cnt,ll k) //用了这个i吗?(和j匹配时)(use[i][j])
{ //上一个是?(行是0,上一行与pre[1]匹配时,以定位)
// printf("(cnt=%lld k=%lld)",cnt,k);
if(!cnt)return;
print(pre[][cnt][k],pre[][cnt][k]);
// if(use[cnt][k])printf("%lld ",b[k]);//主要用在cnt==n时判断输出此i否
printf("%lld ",b[k]);
}
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)scanf("%lld",&a[i]);
scanf("%d",&m);
for(int i=;i<=m;i++)scanf("%lld",&b[i]);
for(int i=;i<=n;i++)
{
ll k=;
for(int j=;j<=m;j++) //若没有选此i,行是之前的(就像d的自然copy一样)
{
if(use[i-][j])
{
pre[][i][j]=i-;pre[][i][j]=j;
}
else
{
pre[][i][j]=pre[][i-][j];pre[][i][j]=pre[][i-][j];
}
}
for(int j=;j<=m;j++)
{
if(a[i]>b[j]&&d[j]>d[k])k=j;
else if(a[i]==b[j]&&d[j]<d[k]+)//选此i
{
d[j]=d[k]+;
if(use[i-][k])
{
pre[][i][j]=i-;pre[][i][j]=k;
}
else
{
pre[][i][j]=pre[][i-][k];pre[][i][j]=k;//用的不是上一行的j,而是k
}
use[i][j]=;
}
}
}
ll mx=,k=;
for(int i=;i<=m;i++)
if(d[i]>mx)mx=d[i],k=i;
printf("%lld\n",mx);
if(use[n][k])print(n,k);
else print(pre[][n][k],k);
return ;
}

另一种记录路径的方法

#include<iostream>
#include<cstdio>
#define ll long long
using namespace std;
const ll INF=;//////防RE,不能大于底下的数组
ll n,m;
ll a[],b[],d[],pre[][];
bool prin[];
void print(ll i,ll j)
{
if(!i)return;
print(i-,pre[i][j]);
if(pre[i-][j]!=pre[i][j]&&!prin[j])printf("%lld ",b[j]),prin[j]=;//以防真实匹配的i的后一个非真实时的输出
// printf("i=%d j=%d\n",i,j); //用d的值判断比较方便,但不想开二维
}
int main()
{
scanf("%lld",&n);
for(ll i=;i<=n;i++)scanf("%lld",&a[i]);
scanf("%lld",&m);
for(ll i=;i<=m;i++)scanf("%lld",&b[i]);
for(ll i=;i<=n;i++)
{
ll k=;
for(ll j=;j<=m;j++)
{
pre[i][j]=j;
if(a[i]>b[j]&&d[j]>d[k])k=j;
else if(a[i]==b[j]&&d[j]<d[k]+)
{
d[j]=d[k]+;
pre[i][j]=k;//当i是第一个,且i与某个匹配时,i的pre与i-1(0)的pre相同了
if(!k)pre[i][j]=INF;
}
}
}
ll k=,mx=;
for(ll i=;i<=m;i++)
if(d[i]>mx)mx=d[i],k=i;
printf("%lld\n",mx);
print(n,k);
}

POJ2127 LICS模板的更多相关文章

  1. 最长公共子序列模板(LCS)和LICS模板

    递归式: 实例图解: 代码: #include<stdio.h> #include<string.h> ; int dp[N][N],f[N][N]; char a[N],b[ ...

  2. 最长公共上升子序列(LICS) 模板

    void LICS() { ;i<=n;i++) { ; ;j<=n;j++) { if (a[i]==b[j]) f[i][j]=ma+; ][j]; ][j]>ma) ma=f[ ...

  3. HDU 1423 LICS 模板

    http://acm.hdu.edu.cn/showproblem.php?pid=1423 4.LICS.O(lena * lenb) 设dp[i][j]表示a[]的前i项,以b[]的第j项结尾时, ...

  4. HDU1423:Greatest Common Increasing Subsequence(LICS)

    Problem Description This is a problem from ZOJ 2432.To make it easyer,you just need output the lengt ...

  5. Jade模板引擎让你飞

    写在前面:现在jade改名成pug了 一.安装 npm install jade 二.基本使用 1.简单使用 p hello jade! 渲染后: <p>hello jade!</p ...

  6. ABP入门系列(2)——通过模板创建MAP版本项目

    一.从官网创建模板项目 进入官网下载模板项目 依次按下图选择: 输入验证码开始下载 下载提示: 二.启动项目 使用VS2015打开项目,还原Nuget包: 设置以Web结尾的项目,设置为启动项目: 打 ...

  7. CMS模板应用调研问卷

    截止目前,已经有数十家网站与我们合作,进行了MIP化改造,在搜索结果页也能看到"闪电标"的出现.除了改造方面的问题,MIP项目组被问到最多的就是:我用了wordpress,我用了织 ...

  8. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  9. 【原创分享·微信支付】C# MVC 微信支付之微信模板消息推送

    微信支付之微信模板消息推送                    今天我要跟大家分享的是“模板消息”的推送,这玩意呢,你说用途嘛,那还是真真的牛逼呐.原因在哪?就是因为它是依赖微信生存的呀,所以他能不 ...

随机推荐

  1. Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required

    Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'e ...

  2. Harbor和YUM部署for CentOS 7

    Harbor部署for CentOS 7 下载 wget https://storage.googleapis.com/harbor-releases/release-1.7.0/harbor-off ...

  3. spring创建单例bean

    (使用的spring版本是3.2.10) 在xml文件中配置一个普通的bean,默认使用单例,创建该bean的调用栈如下: ClassPathXmlApplicationContext //Class ...

  4. 关于向后台请求数据(get请求,无参数传递),返回html代码(实际需要返回的是json数据)的解决方案

    this.$http.get(apis.schoolVideo, { headers: { 'X-Requested-With': 'XMLHttpRequest' } }) 待续

  5. 桥接、nat、host-only

  6. SQL Server 调优系列进阶篇 - 如何维护数据库索引

    前言 上一篇我们研究了如何利用索引在数据库里面调优,简要的介绍了索引的原理,更重要的分析了如何选择索引以及索引的利弊项,有兴趣的可以点击查看. 本篇延续上一篇的内容,继续分析索引这块,侧重索引项的日常 ...

  7. CF 459A && 459B && 459C && 459D && 459E

    http://codeforces.com/contest/459 A题 Pashmak and Garden 化简化简水题,都告诉平行坐标轴了,数据还出了对角线,后面两个点坐标给的范围也不错 #in ...

  8. Swift网络封装库Moya中文手册之RxSwift

    RxSwift Maya提供了一个可选的MoyaProvider 子类 - RxMoyaProvider.在网络请求完成时,我们不再使用 request() 函数的回调闭包,而是使用 Observab ...

  9. DevExpress WPF入门指南:DXWindow应用

    [DevExpress v17.2 版本更新公开课]点击免费报名 DevExpress WPF Window control有一点非常棒,就是可以和其他视觉主题保持统一性.DXWindow class ...

  10. apache ab工具安装测试

    1.安装 安装包下载地址: 将 httpd-2.2.29.tar.gz 解压到目录 /apps/install/httpd-2.2.29 ,这是我放置的位置 cd /apps/install/http ...